mirror of
https://github.com/Theodor-Springmann-Stiftung/musenalm.git
synced 2025-10-29 01:05:32 +00:00
initial data & migrations
This commit is contained in:
49
migrations/1738936553_places.go
Normal file
49
migrations/1738936553_places.go
Normal 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)
|
||||
}
|
||||
54
migrations/1738936568_agents.go
Normal file
54
migrations/1738936568_agents.go
Normal 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)
|
||||
}
|
||||
49
migrations/1738936584_series.go
Normal file
49
migrations/1738936584_series.go
Normal 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)
|
||||
}
|
||||
106
migrations/1738936647_entries.go
Normal file
106
migrations/1738936647_entries.go
Normal 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)
|
||||
}
|
||||
18
migrations/1738936791_r_entries_agents.go
Normal file
18
migrations/1738936791_r_entries_agents.go
Normal 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
|
||||
})
|
||||
}
|
||||
18
migrations/1738936829_r_entries_series.go
Normal file
18
migrations/1738936829_r_entries_series.go
Normal 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
|
||||
})
|
||||
}
|
||||
104
migrations/1738942133_items.go
Normal file
104
migrations/1738942133_items.go
Normal 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)
|
||||
}
|
||||
18
migrations/1738942155_r_items_agents.go
Normal file
18
migrations/1738942155_r_items_agents.go
Normal 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
63
migrations/common.go
Normal 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
1
migrations/consts.go
Normal file
@@ -0,0 +1 @@
|
||||
package migrations
|
||||
Reference in New Issue
Block a user