mirror of
https://github.com/Theodor-Springmann-Stiftung/musenalm.git
synced 2026-02-04 02:25:30 +00:00
+REWORK: migrations
This commit is contained in:
438
migrations/01_tables.go
Normal file
438
migrations/01_tables.go
Normal file
@@ -0,0 +1,438 @@
|
|||||||
|
package migrations
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
||||||
|
"github.com/pocketbase/pocketbase/core"
|
||||||
|
m "github.com/pocketbase/pocketbase/migrations"
|
||||||
|
"maps"
|
||||||
|
"slices"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
m.Register(func(app core.App) error {
|
||||||
|
err := app.Save(places())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = app.Save(agents())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = app.Save(series())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = app.Save(entries(app))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = app.Save(items(app))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = app.Save(contents(app))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
r_entries_agents, err := dbmodels.BasicRelationCollection(app, dbmodels.ENTRIES_TABLE, dbmodels.AGENTS_TABLE, dbmodels.AGENT_RELATIONS)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = app.Save(r_entries_agents)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
r_contents_agents, err := dbmodels.BasicRelationCollection(app, dbmodels.CONTENTS_TABLE, dbmodels.AGENTS_TABLE, dbmodels.AGENT_RELATIONS)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = app.Save(r_contents_agents)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
r_entries_series, err := dbmodels.BasicRelationCollection(app, dbmodels.ENTRIES_TABLE, dbmodels.SERIES_TABLE, dbmodels.SERIES_RELATIONS)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = app.Save(r_entries_series)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = app.Save(r_entries_agents)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}, func(app core.App) error {
|
||||||
|
places, err := app.FindCollectionByNameOrId(dbmodels.PLACES_TABLE)
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return app.Delete(places)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func series() *core.Collection {
|
||||||
|
collection := core.NewBaseCollection(dbmodels.SERIES_TABLE)
|
||||||
|
dbmodels.SetBasicPublicRules(collection)
|
||||||
|
collection.Fields = seriesFields()
|
||||||
|
seriesIndexes(collection)
|
||||||
|
return collection
|
||||||
|
}
|
||||||
|
|
||||||
|
func seriesFields() core.FieldsList {
|
||||||
|
fields := core.NewFieldsList(
|
||||||
|
&core.TextField{Name: dbmodels.SERIES_TITLE_FIELD, Required: true, Presentable: true},
|
||||||
|
&core.TextField{Name: dbmodels.SERIES_PSEUDONYMS_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.REFERENCES_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.SERIES_FREQUENCY_FIELD, Required: false},
|
||||||
|
)
|
||||||
|
|
||||||
|
dbmodels.SetCreatedUpdatedFields(&fields)
|
||||||
|
dbmodels.SetMusenalmIDField(&fields)
|
||||||
|
dbmodels.SetEditorStateField(&fields)
|
||||||
|
dbmodels.SetNotesAndAnnotationsField(&fields)
|
||||||
|
|
||||||
|
return fields
|
||||||
|
}
|
||||||
|
|
||||||
|
func seriesIndexes(collection *core.Collection) {
|
||||||
|
dbmodels.AddMusenalmIDIndex(collection)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.SERIES_TITLE_FIELD, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
func agents() *core.Collection {
|
||||||
|
collection := core.NewBaseCollection(dbmodels.AGENTS_TABLE)
|
||||||
|
dbmodels.SetBasicPublicRules(collection)
|
||||||
|
collection.Fields = agentsFields()
|
||||||
|
agentsIndexes(collection)
|
||||||
|
return collection
|
||||||
|
}
|
||||||
|
|
||||||
|
func agentsFields() core.FieldsList {
|
||||||
|
fields := core.NewFieldsList(
|
||||||
|
&core.TextField{Name: dbmodels.AGENTS_NAME_FIELD, Required: true, Presentable: true},
|
||||||
|
&core.BoolField{Name: dbmodels.AGENTS_CORP_FIELD, Required: false},
|
||||||
|
&core.BoolField{Name: dbmodels.AGENTS_FICTIONAL_FIELD, Required: false},
|
||||||
|
&core.URLField{Name: dbmodels.URI_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.AGENTS_BIOGRAPHICAL_DATA_FIELD, Required: false, Presentable: true},
|
||||||
|
&core.TextField{Name: dbmodels.AGENTS_PROFESSION_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.AGENTS_PSEUDONYMS_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.REFERENCES_FIELD, Required: false},
|
||||||
|
)
|
||||||
|
|
||||||
|
dbmodels.SetCreatedUpdatedFields(&fields)
|
||||||
|
dbmodels.SetMusenalmIDField(&fields)
|
||||||
|
dbmodels.SetEditorStateField(&fields)
|
||||||
|
dbmodels.SetNotesAndAnnotationsField(&fields)
|
||||||
|
|
||||||
|
return fields
|
||||||
|
}
|
||||||
|
|
||||||
|
func agentsIndexes(collection *core.Collection) {
|
||||||
|
dbmodels.AddMusenalmIDIndex(collection)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.AGENTS_NAME_FIELD, false)
|
||||||
|
dbmodels.AddIndexNoCollate(collection, dbmodels.URI_FIELD, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
func places() *core.Collection {
|
||||||
|
places := core.NewBaseCollection(dbmodels.PLACES_TABLE)
|
||||||
|
dbmodels.SetBasicPublicRules(places)
|
||||||
|
places.Fields = placesFields()
|
||||||
|
placesIndexes(places)
|
||||||
|
return places
|
||||||
|
}
|
||||||
|
|
||||||
|
func placesFields() core.FieldsList {
|
||||||
|
fields := core.NewFieldsList(
|
||||||
|
&core.TextField{Name: dbmodels.PLACES_NAME_FIELD, Required: true, Presentable: true},
|
||||||
|
&core.TextField{Name: dbmodels.PLACES_PSEUDONYMS_FIELD, Required: false, Presentable: true},
|
||||||
|
&core.BoolField{Name: dbmodels.AGENTS_FICTIONAL_FIELD, Required: false},
|
||||||
|
&core.URLField{Name: dbmodels.URI_FIELD, Required: false, OnlyDomains: []string{"geonames.org"}},
|
||||||
|
)
|
||||||
|
|
||||||
|
dbmodels.SetCreatedUpdatedFields(&fields)
|
||||||
|
dbmodels.SetMusenalmIDField(&fields)
|
||||||
|
dbmodels.SetEditorStateField(&fields)
|
||||||
|
dbmodels.SetNotesAndAnnotationsField(&fields)
|
||||||
|
|
||||||
|
return fields
|
||||||
|
}
|
||||||
|
|
||||||
|
func placesIndexes(collection *core.Collection) {
|
||||||
|
dbmodels.AddMusenalmIDIndex(collection)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PLACES_NAME_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.URI_FIELD, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
func items(app core.App) *core.Collection {
|
||||||
|
collection := core.NewBaseCollection(dbmodels.ITEMS_TABLE)
|
||||||
|
dbmodels.SetBasicPublicRules(collection)
|
||||||
|
collection.Fields = itemsFields(app)
|
||||||
|
itemsIndexes(collection)
|
||||||
|
return collection
|
||||||
|
}
|
||||||
|
|
||||||
|
func itemsFields(app core.App) core.FieldsList {
|
||||||
|
bcoll, err := app.FindCollectionByNameOrId(dbmodels.ENTRIES_TABLE)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
fields := core.NewFieldsList(
|
||||||
|
&core.RelationField{Name: dbmodels.ENTRIES_TABLE, CollectionId: bcoll.Id, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.ITEMS_IDENTIFIER_FIELD, Required: true, Presentable: true},
|
||||||
|
&core.TextField{Name: dbmodels.ITEMS_LOCATION_FIELD, Required: false, Presentable: true},
|
||||||
|
&core.TextField{Name: dbmodels.ITEMS_OWNER_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.ITEMS_MEDIA_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Presentable: true,
|
||||||
|
Values: dbmodels.ITEM_TYPE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.ITEM_TYPE_VALUES) - 1,
|
||||||
|
},
|
||||||
|
&core.TextField{Name: dbmodels.ITEMS_CONDITION_FIELD, Required: false, Presentable: true},
|
||||||
|
&core.FileField{
|
||||||
|
Name: dbmodels.SCAN_FIELD,
|
||||||
|
Required: false,
|
||||||
|
MaxSize: 100 * 1024 * 1024,
|
||||||
|
MaxSelect: 1000,
|
||||||
|
MimeTypes: dbmodels.MUSENALM_MIME_TYPES,
|
||||||
|
Thumbs: []string{"0x300", "0x500", "0x1000", "300x0", "500x0", "1000x0"},
|
||||||
|
}, // 100 MB a file
|
||||||
|
&core.URLField{Name: dbmodels.URI_FIELD, Required: false, Presentable: false},
|
||||||
|
)
|
||||||
|
|
||||||
|
dbmodels.SetCreatedUpdatedFields(&fields)
|
||||||
|
dbmodels.SetNotesAndAnnotationsField(&fields)
|
||||||
|
dbmodels.SetEditorStateField(&fields)
|
||||||
|
|
||||||
|
return fields
|
||||||
|
}
|
||||||
|
|
||||||
|
func itemsIndexes(collection *core.Collection) {
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.ITEMS_CONDITION_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.ITEMS_OWNER_FIELD, false)
|
||||||
|
dbmodels.AddIndexNoCollate(collection, dbmodels.ITEMS_LOCATION_FIELD, false)
|
||||||
|
dbmodels.AddIndexNoCollate(collection, dbmodels.ITEMS_IDENTIFIER_FIELD, false)
|
||||||
|
dbmodels.AddIndexNoCollate(collection, dbmodels.URI_FIELD, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
func entries(app core.App) *core.Collection {
|
||||||
|
collection := core.NewBaseCollection(dbmodels.ENTRIES_TABLE)
|
||||||
|
dbmodels.SetBasicPublicRules(collection)
|
||||||
|
collection.Fields = entriesFields(app)
|
||||||
|
entriesIndexes(collection)
|
||||||
|
return collection
|
||||||
|
}
|
||||||
|
|
||||||
|
func entriesFields(app core.App) core.FieldsList {
|
||||||
|
places, err := app.FindCollectionByNameOrId(dbmodels.PLACES_TABLE)
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
fields := core.NewFieldsList(
|
||||||
|
// Title information
|
||||||
|
&core.TextField{Name: dbmodels.PREFERRED_TITLE_FIELD, Required: true, Presentable: true},
|
||||||
|
&core.TextField{Name: dbmodels.VARIANT_TITLE_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.PARALLEL_TITLE_FIELD, Required: false},
|
||||||
|
|
||||||
|
// Transcribed information
|
||||||
|
&core.TextField{Name: dbmodels.TITLE_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.SUBTITLE_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.INCIPIT_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
|
||||||
|
&core.TextField{Name: dbmodels.RESPONSIBILITY_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.PLACE_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.PUBLICATION_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
|
||||||
|
// Other discerning Information
|
||||||
|
&core.NumberField{Name: dbmodels.YEAR_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.EDITION_FIELD, Required: false},
|
||||||
|
|
||||||
|
// Media Information
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.LANGUAGE_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: dbmodels.LANGUAGE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.LANGUAGE_VALUES),
|
||||||
|
},
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.CONTENT_TYPE_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: dbmodels.CONTENT_TYPE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.CONTENT_TYPE_VALUES),
|
||||||
|
},
|
||||||
|
|
||||||
|
// Physical Description
|
||||||
|
&core.TextField{Name: dbmodels.EXTENT_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.DIMENSIONS_FIELD, Required: false},
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.CARRIER_TYPE_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: dbmodels.MEDIA_TYPE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.MEDIA_TYPE_VALUES),
|
||||||
|
},
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.CARRIER_TYPE_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: dbmodels.CARRIER_TYPE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.CARRIER_TYPE_VALUES),
|
||||||
|
},
|
||||||
|
|
||||||
|
// Norm Data
|
||||||
|
&core.TextField{Name: dbmodels.REFERENCES_FIELD, Required: false},
|
||||||
|
&core.RelationField{
|
||||||
|
Name: dbmodels.PLACES_TABLE,
|
||||||
|
Required: false,
|
||||||
|
CollectionId: places.Id,
|
||||||
|
CascadeDelete: false,
|
||||||
|
MaxSelect: 5000,
|
||||||
|
},
|
||||||
|
|
||||||
|
// EDIT DATA:
|
||||||
|
&core.JSONField{Name: dbmodels.META_FIELD, Required: false},
|
||||||
|
&core.JSONField{Name: dbmodels.MUSENALM_DEPRECATED_FIELD, Required: false},
|
||||||
|
)
|
||||||
|
|
||||||
|
dbmodels.SetCreatedUpdatedFields(&fields)
|
||||||
|
dbmodels.SetMusenalmIDField(&fields)
|
||||||
|
dbmodels.SetEditorStateField(&fields)
|
||||||
|
dbmodels.SetNotesAndAnnotationsField(&fields)
|
||||||
|
|
||||||
|
return fields
|
||||||
|
}
|
||||||
|
|
||||||
|
func entriesIndexes(collection *core.Collection) {
|
||||||
|
dbmodels.AddMusenalmIDIndex(collection)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PREFERRED_TITLE_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.VARIANT_TITLE_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PARALLEL_TITLE_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.TITLE_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.SUBTITLE_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.INCIPIT_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.RESPONSIBILITY_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PLACE_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PUBLICATION_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.YEAR_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.EDITION_FIELD, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
func contents(app core.App) *core.Collection {
|
||||||
|
collection := core.NewBaseCollection(dbmodels.CONTENTS_TABLE)
|
||||||
|
dbmodels.SetBasicPublicRules(collection)
|
||||||
|
collection.Fields = contentsFields(app)
|
||||||
|
contentsIndexes(collection)
|
||||||
|
return collection
|
||||||
|
}
|
||||||
|
|
||||||
|
func contentsFields(app core.App) core.FieldsList {
|
||||||
|
entries, err := app.FindCollectionByNameOrId(dbmodels.ENTRIES_TABLE)
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
fields := core.NewFieldsList(
|
||||||
|
// Title information
|
||||||
|
&core.TextField{Name: dbmodels.PREFERRED_TITLE_FIELD, Required: true, Presentable: true},
|
||||||
|
&core.TextField{Name: dbmodels.VARIANT_TITLE_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.PARALLEL_TITLE_FIELD, Required: false},
|
||||||
|
|
||||||
|
// Transcribed information
|
||||||
|
&core.TextField{Name: dbmodels.TITLE_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.SUBTITLE_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.INCIPIT_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
|
||||||
|
&core.TextField{Name: dbmodels.RESPONSIBILITY_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.PLACE_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
&core.TextField{Name: dbmodels.PUBLICATION_STMT_FIELD, Required: false, Presentable: false},
|
||||||
|
|
||||||
|
// Other discerning Information
|
||||||
|
&core.NumberField{Name: dbmodels.YEAR_FIELD, Required: false},
|
||||||
|
|
||||||
|
// Media Information
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.LANGUAGE_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: dbmodels.LANGUAGE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.LANGUAGE_VALUES),
|
||||||
|
},
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.CONTENT_TYPE_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: dbmodels.CONTENT_TYPE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.CONTENT_TYPE_VALUES),
|
||||||
|
},
|
||||||
|
|
||||||
|
// Physical Description
|
||||||
|
&core.TextField{Name: dbmodels.EXTENT_FIELD, Required: false},
|
||||||
|
&core.TextField{Name: dbmodels.DIMENSIONS_FIELD, Required: false},
|
||||||
|
|
||||||
|
// Musenalm specific data
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.MUSENALM_INHALTE_TYPE_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: dbmodels.MUSENALM_TYPE_VALUES,
|
||||||
|
MaxSelect: len(dbmodels.MUSENALM_TYPE_VALUES),
|
||||||
|
},
|
||||||
|
&core.SelectField{
|
||||||
|
Name: dbmodels.MUSENALM_PAGINATION_FIELD,
|
||||||
|
Required: false,
|
||||||
|
Values: slices.Collect(maps.Values(dbmodels.MUSENALM_PAGINATION_VALUES)),
|
||||||
|
MaxSelect: len(dbmodels.MUSENALM_PAGINATION_VALUES),
|
||||||
|
},
|
||||||
|
&core.FileField{
|
||||||
|
Name: dbmodels.SCAN_FIELD,
|
||||||
|
Required: false,
|
||||||
|
MaxSize: 100 * 1024 * 1024,
|
||||||
|
MaxSelect: 1000,
|
||||||
|
MimeTypes: dbmodels.MUSENALM_MIME_TYPES,
|
||||||
|
Thumbs: []string{"0x300", "0x500", "0x1000", "300x0", "500x0", "1000x0"},
|
||||||
|
}, // 100 MB a file
|
||||||
|
|
||||||
|
// Band:
|
||||||
|
&core.NumberField{Name: dbmodels.NUMBERING_FIELD, Required: false},
|
||||||
|
&core.RelationField{
|
||||||
|
Name: dbmodels.ENTRIES_TABLE,
|
||||||
|
Required: true,
|
||||||
|
CollectionId: entries.Id,
|
||||||
|
CascadeDelete: false,
|
||||||
|
MaxSelect: 1,
|
||||||
|
MinSelect: 1,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
dbmodels.SetMusenalmIDField(&fields)
|
||||||
|
dbmodels.SetCreatedUpdatedFields(&fields)
|
||||||
|
dbmodels.SetEditorStateField(&fields)
|
||||||
|
dbmodels.SetNotesAndAnnotationsField(&fields)
|
||||||
|
|
||||||
|
return fields
|
||||||
|
}
|
||||||
|
|
||||||
|
func contentsIndexes(collection *core.Collection) {
|
||||||
|
dbmodels.AddMusenalmIDIndex(collection)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PREFERRED_TITLE_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.VARIANT_TITLE_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PARALLEL_TITLE_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.TITLE_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.SUBTITLE_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.INCIPIT_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.RESPONSIBILITY_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PLACE_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.PUBLICATION_STMT_FIELD, false)
|
||||||
|
dbmodels.AddIndex(collection, dbmodels.YEAR_FIELD, false)
|
||||||
|
dbmodels.AddIndexNoCollate(collection, dbmodels.ENTRIES_TABLE, false)
|
||||||
|
}
|
||||||
@@ -8,6 +8,7 @@ import (
|
|||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
m.Register(func(app core.App) error {
|
m.Register(func(app core.App) error {
|
||||||
|
app.Logger().Info("Migrating database to accomodate FTS5")
|
||||||
err := createFTS5(app, dbmodels.AGENTS_TABLE, dbmodels.AGENTS_FTS5_FIELDS)
|
err := createFTS5(app, dbmodels.AGENTS_TABLE, dbmodels.AGENTS_FTS5_FIELDS)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
app.Logger().Error("Error creating FTS5 table for agents", "error", err)
|
app.Logger().Error("Error creating FTS5 table for agents", "error", err)
|
||||||
@@ -1,52 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"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()
|
|
||||||
placesIndexes(places)
|
|
||||||
|
|
||||||
return app.Save(places)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
places, err := app.FindCollectionByNameOrId(dbmodels.PLACES_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(places)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func placesTable() *core.Collection {
|
|
||||||
collection := core.NewBaseCollection(dbmodels.PLACES_TABLE)
|
|
||||||
dbmodels.SetBasicPublicRules(collection)
|
|
||||||
return collection
|
|
||||||
}
|
|
||||||
|
|
||||||
func placesFields() core.FieldsList {
|
|
||||||
fields := core.NewFieldsList(
|
|
||||||
&core.TextField{Name: dbmodels.PLACES_NAME_FIELD, Required: true, Presentable: true},
|
|
||||||
&core.TextField{Name: dbmodels.PLACES_PSEUDONYMS_FIELD, Required: false, Presentable: true},
|
|
||||||
&core.BoolField{Name: dbmodels.AGENTS_FICTIONAL_FIELD, Required: false},
|
|
||||||
&core.URLField{Name: dbmodels.URI_FIELD, Required: false, OnlyDomains: []string{"geonames.org"}},
|
|
||||||
)
|
|
||||||
|
|
||||||
dbmodels.SetCreatedUpdatedFields(&fields)
|
|
||||||
dbmodels.SetMusenalmIDField(&fields)
|
|
||||||
dbmodels.SetEditorStateField(&fields)
|
|
||||||
dbmodels.SetNotesAndAnnotationsField(&fields)
|
|
||||||
|
|
||||||
return fields
|
|
||||||
}
|
|
||||||
|
|
||||||
func placesIndexes(collection *core.Collection) {
|
|
||||||
dbmodels.AddMusenalmIDIndex(collection)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PLACES_NAME_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.URI_FIELD, false)
|
|
||||||
}
|
|
||||||
@@ -1,56 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"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()
|
|
||||||
agentsIndexes(agents)
|
|
||||||
|
|
||||||
return app.Save(agents)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
agents, err := app.FindCollectionByNameOrId(dbmodels.AGENTS_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(agents)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func agentsTable() *core.Collection {
|
|
||||||
collection := core.NewBaseCollection(dbmodels.AGENTS_TABLE)
|
|
||||||
dbmodels.SetBasicPublicRules(collection)
|
|
||||||
return collection
|
|
||||||
}
|
|
||||||
|
|
||||||
func agentsFields() core.FieldsList {
|
|
||||||
fields := core.NewFieldsList(
|
|
||||||
&core.TextField{Name: dbmodels.AGENTS_NAME_FIELD, Required: true, Presentable: true},
|
|
||||||
&core.BoolField{Name: dbmodels.AGENTS_CORP_FIELD, Required: false},
|
|
||||||
&core.BoolField{Name: dbmodels.AGENTS_FICTIONAL_FIELD, Required: false},
|
|
||||||
&core.URLField{Name: dbmodels.URI_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.AGENTS_BIOGRAPHICAL_DATA_FIELD, Required: false, Presentable: true},
|
|
||||||
&core.TextField{Name: dbmodels.AGENTS_PROFESSION_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.AGENTS_PSEUDONYMS_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.REFERENCES_FIELD, Required: false},
|
|
||||||
)
|
|
||||||
|
|
||||||
dbmodels.SetCreatedUpdatedFields(&fields)
|
|
||||||
dbmodels.SetMusenalmIDField(&fields)
|
|
||||||
dbmodels.SetEditorStateField(&fields)
|
|
||||||
dbmodels.SetNotesAndAnnotationsField(&fields)
|
|
||||||
|
|
||||||
return fields
|
|
||||||
}
|
|
||||||
|
|
||||||
func agentsIndexes(collection *core.Collection) {
|
|
||||||
dbmodels.AddMusenalmIDIndex(collection)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.AGENTS_NAME_FIELD, false)
|
|
||||||
dbmodels.AddIndexNoCollate(collection, dbmodels.URI_FIELD, false)
|
|
||||||
}
|
|
||||||
@@ -1,51 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"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()
|
|
||||||
seriesIndexes(series)
|
|
||||||
|
|
||||||
return app.Save(series)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
series, err := app.FindCollectionByNameOrId(dbmodels.SERIES_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(series)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func seriesTable() *core.Collection {
|
|
||||||
collection := core.NewBaseCollection(dbmodels.SERIES_TABLE)
|
|
||||||
dbmodels.SetBasicPublicRules(collection)
|
|
||||||
return collection
|
|
||||||
}
|
|
||||||
|
|
||||||
func seriesFields() core.FieldsList {
|
|
||||||
fields := core.NewFieldsList(
|
|
||||||
&core.TextField{Name: dbmodels.SERIES_TITLE_FIELD, Required: true, Presentable: true},
|
|
||||||
&core.TextField{Name: dbmodels.SERIES_PSEUDONYMS_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.REFERENCES_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.SERIES_FREQUENCY_FIELD, Required: false},
|
|
||||||
)
|
|
||||||
|
|
||||||
dbmodels.SetCreatedUpdatedFields(&fields)
|
|
||||||
dbmodels.SetMusenalmIDField(&fields)
|
|
||||||
dbmodels.SetEditorStateField(&fields)
|
|
||||||
dbmodels.SetNotesAndAnnotationsField(&fields)
|
|
||||||
|
|
||||||
return fields
|
|
||||||
}
|
|
||||||
|
|
||||||
func seriesIndexes(collection *core.Collection) {
|
|
||||||
dbmodels.AddMusenalmIDIndex(collection)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.SERIES_TITLE_FIELD, false)
|
|
||||||
}
|
|
||||||
@@ -1,130 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"github.com/pocketbase/pocketbase/core"
|
|
||||||
m "github.com/pocketbase/pocketbase/migrations"
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
m.Register(func(app core.App) error {
|
|
||||||
entries := entriesTable()
|
|
||||||
fields := entriesFields(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(dbmodels.ENTRIES_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(entries)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func entriesTable() *core.Collection {
|
|
||||||
collection := core.NewBaseCollection(dbmodels.ENTRIES_TABLE)
|
|
||||||
dbmodels.SetBasicPublicRules(collection)
|
|
||||||
return collection
|
|
||||||
}
|
|
||||||
|
|
||||||
func entriesFields(app core.App) *core.FieldsList {
|
|
||||||
places, err := app.FindCollectionByNameOrId(dbmodels.PLACES_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
fields := core.NewFieldsList(
|
|
||||||
// Title information
|
|
||||||
&core.TextField{Name: dbmodels.PREFERRED_TITLE_FIELD, Required: true, Presentable: true},
|
|
||||||
&core.TextField{Name: dbmodels.VARIANT_TITLE_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.PARALLEL_TITLE_FIELD, Required: false},
|
|
||||||
|
|
||||||
// Transcribed information
|
|
||||||
&core.TextField{Name: dbmodels.TITLE_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.SUBTITLE_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.INCIPIT_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
|
|
||||||
&core.TextField{Name: dbmodels.RESPONSIBILITY_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.PLACE_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.PUBLICATION_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
|
|
||||||
// Other discerning Information
|
|
||||||
&core.NumberField{Name: dbmodels.YEAR_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.EDITION_FIELD, Required: false},
|
|
||||||
|
|
||||||
// Media Information
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.LANGUAGE_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: dbmodels.LANGUAGE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.LANGUAGE_VALUES),
|
|
||||||
},
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.CONTENT_TYPE_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: dbmodels.CONTENT_TYPE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.CONTENT_TYPE_VALUES),
|
|
||||||
},
|
|
||||||
|
|
||||||
// Physical Description
|
|
||||||
&core.TextField{Name: dbmodels.EXTENT_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.DIMENSIONS_FIELD, Required: false},
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.CARRIER_TYPE_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: dbmodels.MEDIA_TYPE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.MEDIA_TYPE_VALUES),
|
|
||||||
},
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.CARRIER_TYPE_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: dbmodels.CARRIER_TYPE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.CARRIER_TYPE_VALUES),
|
|
||||||
},
|
|
||||||
|
|
||||||
// Norm Data
|
|
||||||
&core.TextField{Name: dbmodels.REFERENCES_FIELD, Required: false},
|
|
||||||
&core.RelationField{
|
|
||||||
Name: dbmodels.PLACES_TABLE,
|
|
||||||
Required: false,
|
|
||||||
CollectionId: places.Id,
|
|
||||||
CascadeDelete: false,
|
|
||||||
MaxSelect: 5000,
|
|
||||||
},
|
|
||||||
|
|
||||||
// EDIT DATA:
|
|
||||||
&core.JSONField{Name: dbmodels.META_FIELD, Required: false},
|
|
||||||
&core.JSONField{Name: dbmodels.MUSENALM_DEPRECATED_FIELD, Required: false},
|
|
||||||
)
|
|
||||||
|
|
||||||
dbmodels.SetCreatedUpdatedFields(&fields)
|
|
||||||
dbmodels.SetMusenalmIDField(&fields)
|
|
||||||
dbmodels.SetEditorStateField(&fields)
|
|
||||||
dbmodels.SetNotesAndAnnotationsField(&fields)
|
|
||||||
|
|
||||||
return &fields
|
|
||||||
}
|
|
||||||
|
|
||||||
func entriesIndexes(collection *core.Collection) {
|
|
||||||
dbmodels.AddMusenalmIDIndex(collection)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PREFERRED_TITLE_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.VARIANT_TITLE_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PARALLEL_TITLE_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.TITLE_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.SUBTITLE_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.INCIPIT_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.RESPONSIBILITY_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PLACE_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PUBLICATION_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.YEAR_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.EDITION_FIELD, false)
|
|
||||||
}
|
|
||||||
@@ -1,75 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"github.com/pocketbase/pocketbase/core"
|
|
||||||
m "github.com/pocketbase/pocketbase/migrations"
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
m.Register(func(app core.App) error {
|
|
||||||
items := itemsTable()
|
|
||||||
items.Fields = itemsFields(app)
|
|
||||||
itemsIndexes(items)
|
|
||||||
|
|
||||||
return app.Save(items)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
items, err := app.FindCollectionByNameOrId(dbmodels.ITEMS_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(items)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func itemsTable() *core.Collection {
|
|
||||||
collection := core.NewBaseCollection(dbmodels.ITEMS_TABLE)
|
|
||||||
dbmodels.SetBasicPublicRules(collection)
|
|
||||||
return collection
|
|
||||||
}
|
|
||||||
|
|
||||||
func itemsFields(app core.App) core.FieldsList {
|
|
||||||
bcoll, err := app.FindCollectionByNameOrId(dbmodels.ENTRIES_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
fields := core.NewFieldsList(
|
|
||||||
&core.RelationField{Name: dbmodels.ENTRIES_TABLE, CollectionId: bcoll.Id, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.ITEMS_IDENTIFIER_FIELD, Required: true, Presentable: true},
|
|
||||||
&core.TextField{Name: dbmodels.ITEMS_LOCATION_FIELD, Required: false, Presentable: true},
|
|
||||||
&core.TextField{Name: dbmodels.ITEMS_OWNER_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.ITEMS_MEDIA_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Presentable: true,
|
|
||||||
Values: dbmodels.ITEM_TYPE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.ITEM_TYPE_VALUES) - 1,
|
|
||||||
},
|
|
||||||
&core.TextField{Name: dbmodels.ITEMS_CONDITION_FIELD, Required: false, Presentable: true},
|
|
||||||
&core.FileField{
|
|
||||||
Name: dbmodels.SCAN_FIELD,
|
|
||||||
Required: false,
|
|
||||||
MaxSize: 100 * 1024 * 1024,
|
|
||||||
MaxSelect: 1000,
|
|
||||||
MimeTypes: dbmodels.MUSENALM_MIME_TYPES,
|
|
||||||
Thumbs: []string{"0x300", "0x500", "0x1000", "300x0", "500x0", "1000x0"},
|
|
||||||
}, // 100 MB a file
|
|
||||||
&core.URLField{Name: dbmodels.URI_FIELD, Required: false, Presentable: false},
|
|
||||||
)
|
|
||||||
|
|
||||||
dbmodels.SetCreatedUpdatedFields(&fields)
|
|
||||||
dbmodels.SetNotesAndAnnotationsField(&fields)
|
|
||||||
dbmodels.SetEditorStateField(&fields)
|
|
||||||
|
|
||||||
return fields
|
|
||||||
}
|
|
||||||
|
|
||||||
func itemsIndexes(collection *core.Collection) {
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.ITEMS_CONDITION_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.ITEMS_OWNER_FIELD, false)
|
|
||||||
dbmodels.AddIndexNoCollate(collection, dbmodels.ITEMS_LOCATION_FIELD, false)
|
|
||||||
dbmodels.AddIndexNoCollate(collection, dbmodels.ITEMS_IDENTIFIER_FIELD, false)
|
|
||||||
dbmodels.AddIndexNoCollate(collection, dbmodels.URI_FIELD, false)
|
|
||||||
}
|
|
||||||
@@ -1,27 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"github.com/pocketbase/pocketbase/core"
|
|
||||||
m "github.com/pocketbase/pocketbase/migrations"
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
m.Register(func(app core.App) error {
|
|
||||||
collection, err := dbmodels.BasicRelationCollection(app, dbmodels.ENTRIES_TABLE, dbmodels.SERIES_TABLE, dbmodels.SERIES_RELATIONS)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
collection.Fields.Add(&core.TextField{Name: dbmodels.NUMBERING_FIELD, Required: false, Presentable: true})
|
|
||||||
|
|
||||||
return app.Save(collection)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
collection, err := app.FindCollectionByNameOrId(dbmodels.RelationTableName(dbmodels.ENTRIES_TABLE, dbmodels.SERIES_TABLE))
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(collection)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,138 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"maps"
|
|
||||||
"slices"
|
|
||||||
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"github.com/pocketbase/pocketbase/core"
|
|
||||||
m "github.com/pocketbase/pocketbase/migrations"
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
m.Register(func(app core.App) error {
|
|
||||||
partials := partialsTable()
|
|
||||||
fields := partialsFields(app)
|
|
||||||
if fields == nil {
|
|
||||||
return errors.New("Could not find places collection")
|
|
||||||
}
|
|
||||||
|
|
||||||
partials.Fields = *fields
|
|
||||||
partialsIndexes(partials)
|
|
||||||
|
|
||||||
return app.Save(partials)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
partials, err := app.FindCollectionByNameOrId(dbmodels.CONTENTS_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(partials)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func partialsTable() *core.Collection {
|
|
||||||
collection := core.NewBaseCollection(dbmodels.CONTENTS_TABLE)
|
|
||||||
dbmodels.SetBasicPublicRules(collection)
|
|
||||||
return collection
|
|
||||||
}
|
|
||||||
|
|
||||||
func partialsFields(app core.App) *core.FieldsList {
|
|
||||||
entries, err := app.FindCollectionByNameOrId(dbmodels.ENTRIES_TABLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
fields := core.NewFieldsList(
|
|
||||||
// Title information
|
|
||||||
&core.TextField{Name: dbmodels.PREFERRED_TITLE_FIELD, Required: true, Presentable: true},
|
|
||||||
&core.TextField{Name: dbmodels.VARIANT_TITLE_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.PARALLEL_TITLE_FIELD, Required: false},
|
|
||||||
|
|
||||||
// Transcribed information
|
|
||||||
&core.TextField{Name: dbmodels.TITLE_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.SUBTITLE_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.INCIPIT_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
|
|
||||||
&core.TextField{Name: dbmodels.RESPONSIBILITY_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.PLACE_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
&core.TextField{Name: dbmodels.PUBLICATION_STMT_FIELD, Required: false, Presentable: false},
|
|
||||||
|
|
||||||
// Other discerning Information
|
|
||||||
&core.NumberField{Name: dbmodels.YEAR_FIELD, Required: false},
|
|
||||||
|
|
||||||
// Media Information
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.LANGUAGE_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: dbmodels.LANGUAGE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.LANGUAGE_VALUES),
|
|
||||||
},
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.CONTENT_TYPE_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: dbmodels.CONTENT_TYPE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.CONTENT_TYPE_VALUES),
|
|
||||||
},
|
|
||||||
|
|
||||||
// Physical Description
|
|
||||||
&core.TextField{Name: dbmodels.EXTENT_FIELD, Required: false},
|
|
||||||
&core.TextField{Name: dbmodels.DIMENSIONS_FIELD, Required: false},
|
|
||||||
|
|
||||||
// Musenalm specific data
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.MUSENALM_INHALTE_TYPE_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: dbmodels.MUSENALM_TYPE_VALUES,
|
|
||||||
MaxSelect: len(dbmodels.MUSENALM_TYPE_VALUES),
|
|
||||||
},
|
|
||||||
&core.SelectField{
|
|
||||||
Name: dbmodels.MUSENALM_PAGINATION_FIELD,
|
|
||||||
Required: false,
|
|
||||||
Values: slices.Collect(maps.Values(dbmodels.MUSENALM_PAGINATION_VALUES)),
|
|
||||||
MaxSelect: len(dbmodels.MUSENALM_PAGINATION_VALUES),
|
|
||||||
},
|
|
||||||
&core.FileField{
|
|
||||||
Name: dbmodels.SCAN_FIELD,
|
|
||||||
Required: false,
|
|
||||||
MaxSize: 100 * 1024 * 1024,
|
|
||||||
MaxSelect: 1000,
|
|
||||||
MimeTypes: dbmodels.MUSENALM_MIME_TYPES,
|
|
||||||
Thumbs: []string{"0x300", "0x500", "0x1000", "300x0", "500x0", "1000x0"},
|
|
||||||
}, // 100 MB a file
|
|
||||||
|
|
||||||
// Band:
|
|
||||||
&core.NumberField{Name: dbmodels.NUMBERING_FIELD, Required: false},
|
|
||||||
&core.RelationField{
|
|
||||||
Name: dbmodels.ENTRIES_TABLE,
|
|
||||||
Required: true,
|
|
||||||
CollectionId: entries.Id,
|
|
||||||
CascadeDelete: false,
|
|
||||||
MaxSelect: 1,
|
|
||||||
MinSelect: 1,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
dbmodels.SetMusenalmIDField(&fields)
|
|
||||||
dbmodels.SetCreatedUpdatedFields(&fields)
|
|
||||||
dbmodels.SetEditorStateField(&fields)
|
|
||||||
dbmodels.SetNotesAndAnnotationsField(&fields)
|
|
||||||
|
|
||||||
return &fields
|
|
||||||
}
|
|
||||||
|
|
||||||
func partialsIndexes(collection *core.Collection) {
|
|
||||||
dbmodels.AddMusenalmIDIndex(collection)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PREFERRED_TITLE_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.VARIANT_TITLE_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PARALLEL_TITLE_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.TITLE_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.SUBTITLE_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.INCIPIT_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.RESPONSIBILITY_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PLACE_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.PUBLICATION_STMT_FIELD, false)
|
|
||||||
dbmodels.AddIndex(collection, dbmodels.YEAR_FIELD, false)
|
|
||||||
dbmodels.AddIndexNoCollate(collection, dbmodels.ENTRIES_TABLE, false)
|
|
||||||
}
|
|
||||||
@@ -1,25 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"github.com/pocketbase/pocketbase/core"
|
|
||||||
m "github.com/pocketbase/pocketbase/migrations"
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
m.Register(func(app core.App) error {
|
|
||||||
collections, err := dbmodels.BasicRelationCollection(app, dbmodels.CONTENTS_TABLE, dbmodels.AGENTS_TABLE, dbmodels.AGENT_RELATIONS)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Save(collections)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
collection, err := app.FindCollectionByNameOrId(dbmodels.RelationTableName(dbmodels.CONTENTS_TABLE, dbmodels.AGENTS_TABLE))
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(collection)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,25 +0,0 @@
|
|||||||
package migrations
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
|
|
||||||
"github.com/pocketbase/pocketbase/core"
|
|
||||||
m "github.com/pocketbase/pocketbase/migrations"
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
m.Register(func(app core.App) error {
|
|
||||||
collections, err := dbmodels.BasicRelationCollection(app, dbmodels.ENTRIES_TABLE, dbmodels.AGENTS_TABLE, dbmodels.AGENT_RELATIONS)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Save(collections)
|
|
||||||
}, func(app core.App) error {
|
|
||||||
collection, err := app.FindCollectionByNameOrId(dbmodels.RelationTableName(dbmodels.ENTRIES_TABLE, dbmodels.AGENTS_TABLE))
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return app.Delete(collection)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user