initial data & migrations

This commit is contained in:
Simon Martens
2025-02-07 17:42:10 +01:00
parent 45f28effe8
commit 7ff6bd9d28
85 changed files with 2481809 additions and 0 deletions

View File

@@ -0,0 +1,49 @@
package migrations
import (
"github.com/Theodor-Springmann-Stiftung/musenalm/models"
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
places := placesTable()
places.Fields = placesFields(places)
placesIndexes(places)
return app.Save(places)
}, func(app core.App) error {
places, err := app.FindCollectionByNameOrId(models.PLACES_TABLE)
if err != nil {
return nil
}
return app.Delete(places)
})
}
func placesTable() *core.Collection {
collection := core.NewBaseCollection(models.PLACES_TABLE)
setBasicPublicRules(collection)
return collection
}
func placesFields(collection *core.Collection) core.FieldsList {
fields := core.NewFieldsList(
&core.TextField{Name: "name", Required: true, Presentable: true},
&core.BoolField{Name: "fictional", Required: false},
&core.URLField{Name: "registry_domains", Required: false, OnlyDomains: []string{"geonames.org"}},
)
setMusenalmIDField(&fields)
setEditorStateField(&fields)
setNotesAndAnnotationsField(&fields)
return fields
}
func placesIndexes(collection *core.Collection) {
addMusenalmIDIndex(collection)
addIndex(collection, "name", false)
}

View File

@@ -0,0 +1,54 @@
package migrations
import (
"github.com/Theodor-Springmann-Stiftung/musenalm/models"
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
agents := agentsTable()
agents.Fields = agentsFields(agents)
agentsIndexes(agents)
return app.Save(agents)
}, func(app core.App) error {
agents, err := app.FindCollectionByNameOrId(models.AGENTS_TABLE)
if err != nil {
return nil
}
return app.Delete(agents)
})
}
func agentsTable() *core.Collection {
collection := core.NewBaseCollection(models.AGENTS_TABLE)
setBasicPublicRules(collection)
return collection
}
func agentsFields(collection *core.Collection) core.FieldsList {
fields := core.NewFieldsList(
&core.TextField{Name: "name", Required: true, Presentable: true},
&core.BoolField{Name: "corporate_body", Required: false},
&core.BoolField{Name: "fictional", Required: false},
&core.URLField{Name: "registry_domains", Required: false},
&core.TextField{Name: "biographical_data", Required: false, Presentable: true},
&core.TextField{Name: "profession", Required: false},
&core.TextField{Name: "pseudonyms", Required: false},
&core.TextField{Name: "references", Required: false},
)
setMusenalmIDField(&fields)
setEditorStateField(&fields)
setNotesAndAnnotationsField(&fields)
return fields
}
func agentsIndexes(collection *core.Collection) {
addMusenalmIDIndex(collection)
addIndex(collection, "name", false)
}

View File

@@ -0,0 +1,49 @@
package migrations
import (
"github.com/Theodor-Springmann-Stiftung/musenalm/models"
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
series := seriesTable()
series.Fields = seriesFields(series)
seriesIndexes(series)
return app.Save(series)
}, func(app core.App) error {
series, err := app.FindCollectionByNameOrId(models.SERIES_TABLE)
if err != nil {
return nil
}
return app.Delete(series)
})
}
func seriesTable() *core.Collection {
collection := core.NewBaseCollection(models.SERIES_TABLE)
setBasicPublicRules(collection)
return collection
}
func seriesFields(collection *core.Collection) core.FieldsList {
fields := core.NewFieldsList(
&core.TextField{Name: "name", Required: true, Presentable: true},
&core.TextField{Name: "pseudonyms", Required: false},
&core.TextField{Name: "references", Required: false},
)
setMusenalmIDField(&fields)
setEditorStateField(&fields)
setNotesAndAnnotationsField(&fields)
return fields
}
func seriesIndexes(collection *core.Collection) {
addMusenalmIDIndex(collection)
addIndex(collection, "name", false)
}

View File

@@ -0,0 +1,106 @@
package migrations
import (
"errors"
"github.com/Theodor-Springmann-Stiftung/musenalm/models"
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
entries := entriesTable()
fields := entriesFields(entries, app)
if fields == nil {
return errors.New("Could not find places collection")
}
entries.Fields = *fields
entriesIndexes(entries)
return app.Save(entries)
}, func(app core.App) error {
entries, err := app.FindCollectionByNameOrId(models.ENTRIES_TABLE)
if err != nil {
return nil
}
return app.Delete(entries)
})
}
func entriesTable() *core.Collection {
collection := core.NewBaseCollection(models.ENTRIES_TABLE)
setBasicPublicRules(collection)
return collection
}
func entriesFields(collection *core.Collection, app core.App) *core.FieldsList {
places, err := app.FindCollectionByNameOrId(models.PLACES_TABLE)
if err != nil {
return nil
}
fields := core.NewFieldsList(
// Title information
&core.TextField{Name: "preferredtitle", Required: true, Presentable: true},
&core.TextField{Name: "varianttitle", Required: false, Presentable: false},
&core.BoolField{Name: "paralleltitle", Required: false},
// Transcribed information
&core.TextField{Name: "title_statement", Required: false, Presentable: false},
&core.TextField{Name: "subtitle_statement", Required: false, Presentable: false},
&core.TextField{Name: "incipit_statement", Required: false, Presentable: false},
&core.TextField{Name: "responsibility_statement", Required: false, Presentable: false},
&core.TextField{Name: "place_statement", Required: false, Presentable: false},
&core.TextField{Name: "publication_statement", Required: false, Presentable: false},
// Other discerning Information
&core.NumberField{Name: "year", Required: false},
&core.TextField{Name: "edition", Required: false},
// Media Information
&core.SelectField{Name: "language", Required: false, Values: models.LANGUAGE_VALUES, MaxSelect: len(models.LANGUAGE_VALUES)},
&core.SelectField{Name: "content_type", Required: false, Values: models.CONTENT_TYPE_VALUES, MaxSelect: len(models.CONTENT_TYPE_VALUES)},
// Physical Description
&core.TextField{Name: "extent", Required: false},
&core.TextField{Name: "dimensions", Required: false},
&core.SelectField{Name: "media_type", Required: false, Values: models.MEDIA_TYPE_VALUES, MaxSelect: len(models.MEDIA_TYPE_VALUES)},
&core.SelectField{Name: "carrier_type", Required: false, Values: models.CARRIER_TYPE_VALUES, MaxSelect: len(models.CARRIER_TYPE_VALUES)},
// Norm Data
&core.TextField{Name: "references", Required: false},
&core.RelationField{Name: "places", Required: false, CollectionId: places.Id, CascadeDelete: false, MaxSelect: 5000},
// Musenalm specific data
&core.SelectField{Name: "musenalm_status", Required: false, Values: models.MUSENALM_STATUS_VALUES, MaxSelect: len(models.MUSENALM_STATUS_VALUES)},
&core.JSONField{Name: "musenalm_deprecated", Required: false},
// Exemplare:
&core.JSONField{Name: "items", Required: false},
)
setMusenalmIDField(&fields)
setEditorStateField(&fields)
setNotesAndAnnotationsField(&fields)
return &fields
}
func entriesIndexes(collection *core.Collection) {
addMusenalmIDIndex(collection)
addIndex(collection, "preferredtitle", false)
addIndex(collection, "varianttile", false)
addIndex(collection, "paralleltitle", false)
addIndex(collection, "title_statement", false)
addIndex(collection, "subtitle_statement", false)
addIndex(collection, "incipit_statement", false)
addIndex(collection, "responsibility_statement", false)
addIndex(collection, "place_statement", false)
addIndex(collection, "publication_statement", false)
addIndex(collection, "year", false)
addIndex(collection, "edition", false)
}

View File

@@ -0,0 +1,18 @@
package migrations
import (
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
// add up queries...
return nil
}, func(app core.App) error {
// add down queries...
return nil
})
}

View File

@@ -0,0 +1,18 @@
package migrations
import (
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
// add up queries...
return nil
}, func(app core.App) error {
// add down queries...
return nil
})
}

View File

@@ -0,0 +1,104 @@
package migrations
import (
"errors"
"github.com/Theodor-Springmann-Stiftung/musenalm/models"
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
items := itemsTable()
fields := itemsFields(items, app)
if fields == nil {
return errors.New("Could not find places collection")
}
items.Fields = *fields
itemsIndexes(items)
return app.Save(items)
}, func(app core.App) error {
items, err := app.FindCollectionByNameOrId(models.ITEMS_TABLE)
if err != nil {
return nil
}
return app.Delete(items)
})
}
func itemsTable() *core.Collection {
collection := core.NewBaseCollection(models.ITEMS_TABLE)
setBasicPublicRules(collection)
return collection
}
func itemsFields(collection *core.Collection, app core.App) *core.FieldsList {
entries, err := app.FindCollectionByNameOrId(models.ENTRIES_TABLE)
if err != nil {
return nil
}
fields := core.NewFieldsList(
// Title information
&core.TextField{Name: "preferredtitle", Required: true, Presentable: true},
&core.TextField{Name: "varianttitle", Required: false, Presentable: false},
&core.BoolField{Name: "paralleltitle", Required: false},
// Transcribed information
&core.TextField{Name: "title_statement", Required: false, Presentable: false},
&core.TextField{Name: "subtitle_statement", Required: false, Presentable: false},
&core.TextField{Name: "incipit_statement", Required: false, Presentable: false},
&core.TextField{Name: "responsibility_statement", Required: false, Presentable: false},
&core.TextField{Name: "place_statement", Required: false, Presentable: false},
&core.TextField{Name: "publication_statement", Required: false, Presentable: false},
// Other discerning Information
&core.NumberField{Name: "year", Required: false},
&core.TextField{Name: "edition", Required: false},
// Media Information
&core.SelectField{Name: "language", Required: false, Values: models.LANGUAGE_VALUES, MaxSelect: len(models.LANGUAGE_VALUES)},
&core.SelectField{Name: "content_type", Required: false, Values: models.CONTENT_TYPE_VALUES, MaxSelect: len(models.CONTENT_TYPE_VALUES)},
// Physical Description
&core.TextField{Name: "extent", Required: false},
&core.TextField{Name: "dimensions", Required: false},
&core.SelectField{Name: "media_type", Required: false, Values: models.MEDIA_TYPE_VALUES, MaxSelect: len(models.MEDIA_TYPE_VALUES)},
&core.SelectField{Name: "carrier_type", Required: false, Values: models.CARRIER_TYPE_VALUES, MaxSelect: len(models.CARRIER_TYPE_VALUES)},
// Musenalm specific data
&core.SelectField{Name: "musenalm_type", Required: false, Values: models.MUSENALM_TYPE_VALUES, MaxSelect: len(models.MUSENALM_TYPE_VALUES)},
&core.SelectField{Name: "pagination", Required: false, Values: models.MUSENALM_PAGINATION_VALUES, MaxSelect: len(models.MUSENALM_PAGINATION_VALUES)},
&core.FileField{Name: "scans", Required: false, MaxSize: 100 * 1024 * 1024, MaxSelect: 100, MimeTypes: models.MUSENALM_MIME_TYPES, Thumbs: []string{"0x300", "0x500", "0x1000", "300x0", "500x0", "1000x0"}}, // 100 MB
// Band:
&core.NumberField{Name: "running_number", Required: false},
&core.RelationField{Name: "entries", Required: true, CollectionId: entries.Id, CascadeDelete: false, MaxSelect: 1, MinSelect: 1},
)
setMusenalmIDField(&fields)
setEditorStateField(&fields)
setNotesAndAnnotationsField(&fields)
return &fields
}
func itemsIndexes(collection *core.Collection) {
addMusenalmIDIndex(collection)
addIndex(collection, "preferredtitle", false)
addIndex(collection, "varianttile", false)
addIndex(collection, "paralleltitle", false)
addIndex(collection, "title_statement", false)
addIndex(collection, "subtitle_statement", false)
addIndex(collection, "incipit_statement", false)
addIndex(collection, "responsibility_statement", false)
addIndex(collection, "place_statement", false)
addIndex(collection, "publication_statement", false)
addIndex(collection, "year", false)
addIndex(collection, "edition", false)
}

View File

@@ -0,0 +1,18 @@
package migrations
import (
"github.com/pocketbase/pocketbase/core"
m "github.com/pocketbase/pocketbase/migrations"
)
func init() {
m.Register(func(app core.App) error {
// add up queries...
return nil
}, func(app core.App) error {
// add down queries...
return nil
})
}

63
migrations/common.go Normal file
View File

@@ -0,0 +1,63 @@
package migrations
import (
"github.com/Theodor-Springmann-Stiftung/musenalm/models"
"github.com/pocketbase/pocketbase/core"
"github.com/pocketbase/pocketbase/tools/types"
)
func setBasicPublicRules(collection *core.Collection) {
collection.ViewRule = types.Pointer("@request.auth.id != ''")
collection.CreateRule = types.Pointer("@request.auth.id != '' && @request.body.user = @request.auth.id")
collection.UpdateRule = types.Pointer(`
@request.auth.id != '' &&
user = @request.auth.id &&
(@request.body.user:isset = false || @request.body.user = @request.auth.id)
`)
}
func setMusenalmIDField(fieldlist *core.FieldsList) {
fieldlist.Add(&core.TextField{Name: models.MUSENALMID_FIELD, Max: 64, Required: false})
}
func setEditorStateField(fieldlist *core.FieldsList) {
fieldlist.Add(&core.SelectField{Name: models.EDITSTATE_FIELD, Required: false, Values: models.EDITORSTATE_VALUES})
}
func setNotesAndAnnotationsField(fieldlist *core.FieldsList) {
fieldlist.Add(&core.EditorField{Name: models.ANNOTATION_FIELD, Required: false, ConvertURLs: false})
fieldlist.Add(&core.EditorField{Name: models.COMMENT_FIELD, Required: false, ConvertURLs: false})
}
func addMusenalmIDIndex(collection *core.Collection) {
addIndex(collection, models.MUSENALMID_FIELD, true)
}
func addIndex(collection *core.Collection, field string, unique bool) {
name := collection.Name
collection.AddIndex("idx_"+name+"_"+field, unique, field, "")
}
func createAgentRelationsTable(app core.App, sourcetablename, targettablename, tablename string) error {
return nil
}
func basicRelationFields(app core.App, sourcetablename, targettablename string, relations []string) (core.FieldsList, error) {
stable, err := app.FindCollectionByNameOrId(sourcetablename)
if err != nil {
return nil, err
}
ttable, err := app.FindCollectionByNameOrId(targettablename)
if err != nil {
return nil, err
}
fields := core.NewFieldsList(
&core.RelationField{Name: stable.Name, Required: true, CollectionId: stable.Id},
&core.RelationField{Name: ttable.Name, Required: true, CollectionId: ttable.Id},
&core.TextField{Name: "relation_type", Required: true},
)
return fields, nil
}

1
migrations/consts.go Normal file
View File

@@ -0,0 +1 @@
package migrations