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
This commit is contained in:
parent
94ca36f470
commit
375a3305bb
11 changed files with 931 additions and 2 deletions
144
pocketbase/pb_migrations/1779215839_created_vereine.js
Normal file
144
pocketbase/pb_migrations/1779215839_created_vereine.js
Normal file
|
|
@ -0,0 +1,144 @@
|
|||
/// <reference path="../pb_data/types.d.ts" />
|
||||
migrate((app) => {
|
||||
const collection = new Collection({
|
||||
"createRule": null,
|
||||
"deleteRule": null,
|
||||
"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"
|
||||
},
|
||||
{
|
||||
"autogeneratePattern": "",
|
||||
"help": "",
|
||||
"hidden": false,
|
||||
"id": "text1579384326",
|
||||
"max": 0,
|
||||
"min": 0,
|
||||
"name": "name",
|
||||
"pattern": "",
|
||||
"presentable": false,
|
||||
"primaryKey": false,
|
||||
"required": true,
|
||||
"system": false,
|
||||
"type": "text"
|
||||
},
|
||||
{
|
||||
"autogeneratePattern": "",
|
||||
"help": "",
|
||||
"hidden": false,
|
||||
"id": "text3525840331",
|
||||
"max": 0,
|
||||
"min": 0,
|
||||
"name": "plz",
|
||||
"pattern": "",
|
||||
"presentable": false,
|
||||
"primaryKey": false,
|
||||
"required": false,
|
||||
"system": false,
|
||||
"type": "text"
|
||||
},
|
||||
{
|
||||
"autogeneratePattern": "",
|
||||
"help": "",
|
||||
"hidden": false,
|
||||
"id": "text4138466142",
|
||||
"max": 0,
|
||||
"min": 0,
|
||||
"name": "ort",
|
||||
"pattern": "",
|
||||
"presentable": false,
|
||||
"primaryKey": false,
|
||||
"required": false,
|
||||
"system": false,
|
||||
"type": "text"
|
||||
},
|
||||
{
|
||||
"help": "",
|
||||
"hidden": false,
|
||||
"id": "select1497100012",
|
||||
"maxSelect": 1,
|
||||
"name": "bundesland",
|
||||
"presentable": false,
|
||||
"required": false,
|
||||
"system": false,
|
||||
"type": "select",
|
||||
"values": [
|
||||
"BW",
|
||||
"BY",
|
||||
"BE",
|
||||
"BB",
|
||||
"HB",
|
||||
"HH",
|
||||
"HE",
|
||||
"MV",
|
||||
"NI",
|
||||
"NW",
|
||||
"RP",
|
||||
"SL",
|
||||
"SN",
|
||||
"ST",
|
||||
"SH",
|
||||
"TH"
|
||||
]
|
||||
},
|
||||
{
|
||||
"help": "",
|
||||
"hidden": false,
|
||||
"id": "select3713686397",
|
||||
"maxSelect": 1,
|
||||
"name": "plan",
|
||||
"presentable": false,
|
||||
"required": false,
|
||||
"system": false,
|
||||
"type": "select",
|
||||
"values": [
|
||||
"free",
|
||||
"starter",
|
||||
"wachstum",
|
||||
"verband"
|
||||
]
|
||||
},
|
||||
{
|
||||
"autogeneratePattern": "",
|
||||
"help": "",
|
||||
"hidden": false,
|
||||
"id": "text1888339527",
|
||||
"max": 0,
|
||||
"min": 0,
|
||||
"name": "stripe_customer_id",
|
||||
"pattern": "",
|
||||
"presentable": false,
|
||||
"primaryKey": false,
|
||||
"required": false,
|
||||
"system": false,
|
||||
"type": "text"
|
||||
}
|
||||
],
|
||||
"id": "pbc_3589557411",
|
||||
"indexes": [],
|
||||
"listRule": "@request.auth.verein_id = id",
|
||||
"name": "vereine",
|
||||
"system": false,
|
||||
"type": "base",
|
||||
"updateRule": "@request.auth.verein_id = id",
|
||||
"viewRule": "@request.auth.verein_id = id"
|
||||
});
|
||||
|
||||
return app.save(collection);
|
||||
}, (app) => {
|
||||
const collection = app.findCollectionByNameOrId("pbc_3589557411");
|
||||
|
||||
return app.delete(collection);
|
||||
})
|
||||
Loading…
Add table
Add a link
Reference in a new issue