vereinshaus/pocketbase/pb_migrations/1779215948_created_einzuege.js
rene 375a3305bb Add PocketBase schema migrations and migration pipeline
- 8 collections: vereine, gruppen, mitglieder, beitraege, einzuege,
  termine, nachrichten, push_subscriptions
- verein_id relation added to users (multi-tenant isolation)
- API rules enforce tenant separation via @request.auth.verein_id
- docker-compose: --migrationsDir=/pb_data/migrations flag + volume mount
- Makefile: migrations sync step added to deploy target
2026-05-19 20:40:47 +02:00

123 lines
3 KiB
JavaScript

/// <reference path="../pb_data/types.d.ts" />
migrate((app) => {
const collection = new Collection({
"createRule": "@request.auth.verein_id = mitglied_id.verein_id",
"deleteRule": "@request.auth.verein_id = mitglied_id.verein_id",
"fields": [
{
"autogeneratePattern": "[a-z0-9]{15}",
"help": "",
"hidden": false,
"id": "text3208210256",
"max": 15,
"min": 15,
"name": "id",
"pattern": "^[a-z0-9]+$",
"presentable": false,
"primaryKey": true,
"required": true,
"system": true,
"type": "text"
},
{
"cascadeDelete": true,
"collectionId": "pbc_2707111162",
"help": "",
"hidden": false,
"id": "relation3039789658",
"maxSelect": 1,
"minSelect": 0,
"name": "mitglied_id",
"presentable": false,
"required": true,
"system": false,
"type": "relation"
},
{
"cascadeDelete": false,
"collectionId": "pbc_3218207135",
"help": "",
"hidden": false,
"id": "relation715527895",
"maxSelect": 1,
"minSelect": 0,
"name": "beitrag_id",
"presentable": false,
"required": true,
"system": false,
"type": "relation"
},
{
"help": "",
"hidden": false,
"id": "number3107246631",
"max": null,
"min": null,
"name": "betrag",
"onlyInt": false,
"presentable": false,
"required": true,
"system": false,
"type": "number"
},
{
"help": "",
"hidden": false,
"id": "date3314956993",
"max": "",
"min": "",
"name": "faellig_am",
"presentable": false,
"required": false,
"system": false,
"type": "date"
},
{
"help": "",
"hidden": false,
"id": "select2063623452",
"maxSelect": 1,
"name": "status",
"presentable": false,
"required": false,
"system": false,
"type": "select",
"values": [
"ausstehend",
"bezahlt",
"fehlgeschlagen",
"storniert"
]
},
{
"autogeneratePattern": "",
"help": "",
"hidden": false,
"id": "text4235393406",
"max": 0,
"min": 0,
"name": "stripe_payment_intent_id",
"pattern": "",
"presentable": false,
"primaryKey": false,
"required": false,
"system": false,
"type": "text"
}
],
"id": "pbc_659326735",
"indexes": [],
"listRule": "@request.auth.verein_id = mitglied_id.verein_id",
"name": "einzuege",
"system": false,
"type": "base",
"updateRule": "@request.auth.verein_id = mitglied_id.verein_id",
"viewRule": "@request.auth.verein_id = mitglied_id.verein_id"
});
return app.save(collection);
}, (app) => {
const collection = app.findCollectionByNameOrId("pbc_659326735");
return app.delete(collection);
})