Better migration handling

This commit is contained in:
Mike Schwörer 2024-09-20 23:50:34 +02:00
parent 7546c2a1a4
commit d9a14c9973
Signed by: Mikescher
GPG Key ID: D3C7172E0A70F8CF
7 changed files with 58 additions and 73 deletions

View File

@ -15,39 +15,46 @@ import (
func main() { func main() {
exerr.Init(exerr.ErrorPackageConfigInit{}) exerr.Init(exerr.ErrorPackageConfigInit{})
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second) ctx, cancel := context.WithTimeout(context.Background(), 1011*time.Second)
defer cancel() defer cancel()
if !langext.InArray("sqlite3", sql.Drivers()) { if !langext.InArray("sqlite3", sql.Drivers()) {
sqlite.RegisterAsSQLITE3() sqlite.RegisterAsSQLITE3()
} }
fmt.Println() for key, schemaObj := range langext.AsSortedBy(langext.MapToArr(schema.PrimarySchema), func(v langext.MapEntry[int, schema.Def]) int { return v.Key }) {
var h0 string
for i := 2; i <= schema.PrimarySchemaVersion; i++ { if key == 1 {
h0, err := sq.HashGoSqliteSchema(ctx, schema.PrimarySchema[i].SQL) h0 = "N/A"
} else {
var err error
h0, err = sq.HashGoSqliteSchema(ctx, schemaObj.Value.SQL)
if err != nil { if err != nil {
h0 = "ERR" h0 = "ERR"
} }
fmt.Printf("PrimarySchema%d := %s\n", i, h0) }
fmt.Printf("PrimarySchema [%d] := %s%s\n", schemaObj.Key, h0, langext.Conditional(schemaObj.Key == schema.PrimarySchemaVersion, " (active)", ""))
} }
for i := 1; i <= schema.RequestsSchemaVersion; i++ { fmt.Printf("\n")
h0, err := sq.HashGoSqliteSchema(ctx, schema.RequestsSchema[i].SQL)
for _, schemaObj := range langext.AsSortedBy(langext.MapToArr(schema.RequestsSchema), func(v langext.MapEntry[int, schema.Def]) int { return v.Key }) {
h0, err := sq.HashGoSqliteSchema(ctx, schemaObj.Value.SQL)
if err != nil { if err != nil {
h0 = "ERR" h0 = "ERR"
} }
fmt.Printf("RequestsSchema%d := %s\n", i, h0) fmt.Printf("RequestsSchema [%d] := %s%s\n", schemaObj.Key, h0, langext.Conditional(schemaObj.Key == schema.RequestsSchemaVersion, " (active)", ""))
} }
for i := 1; i <= schema.LogsSchemaVersion; i++ { fmt.Printf("\n")
h0, err := sq.HashGoSqliteSchema(ctx, schema.LogsSchema[i].SQL)
for _, schemaObj := range langext.AsSortedBy(langext.MapToArr(schema.LogsSchema), func(v langext.MapEntry[int, schema.Def]) int { return v.Key }) {
h0, err := sq.HashGoSqliteSchema(ctx, schemaObj.Value.SQL)
if err != nil { if err != nil {
h0 = "ERR" h0 = "ERR"
} }
fmt.Printf("LogsSchema%d := %s\n", i, h0) fmt.Printf("LogsSchema [%d] := %s%s\n", schemaObj.Key, h0, langext.Conditional(schemaObj.Key == schema.LogsSchemaVersion, " (active)", ""))
} }
fmt.Println() fmt.Printf("\n")
} }

View File

@ -1,6 +1,9 @@
package schema package schema
import _ "embed" import (
"embed"
_ "embed"
)
type Def struct { type Def struct {
SQL string SQL string
@ -8,75 +11,50 @@ type Def struct {
MigScript string MigScript string
} }
//go:embed primary_1.ddl //go:embed *.ddl
var primarySchema1 string //go:embed *.sql
var assets embed.FS
//go:embed primary_2.ddl
var primarySchema2 string
//go:embed primary_3.ddl
var primarySchema3 string
//go:embed primary_4.ddl
var primarySchema4 string
//go:embed primary_5.ddl
var primarySchema5 string
//go:embed primary_6.ddl
var primarySchema6 string
//go:embed primary_7.ddl
var primarySchema7 string
//go:embed primary_8.ddl
var primarySchema8 string
//go:embed primary_migration_3_4.ddl
var primaryMigration_3_4 string
//go:embed primary_migration_4_5.ddl
var primaryMigration_4_5 string
//go:embed primary_migration_5_6.ddl
var primaryMigration_5_6 string
//go:embed primary_migration_6_7.ddl
var primaryMigration_6_7 string
//go:embed primary_migration_7_8.ddl
var primaryMigration_7_8 string
//go:embed requests_1.ddl
var requestsSchema1 string
//go:embed logs_1.ddl
var logsSchema1 string
var PrimarySchema = map[int]Def{ var PrimarySchema = map[int]Def{
0: {"", "", ""}, 0: {"", "", ""},
1: {primarySchema1, "f2b2847f32681a7178e405553beea4a324034915a0c5a5dc70b3c6abbcc852f2", ""}, 1: {readDDL("primary_1.ddl"), "f2b2847f32681a7178e405553beea4a324034915a0c5a5dc70b3c6abbcc852f2", ""},
2: {primarySchema2, "07ed1449114416ed043084a30e0722a5f97bf172161338d2f7106a8dfd387d0a", ""}, 2: {readDDL("primary_2.ddl"), "07ed1449114416ed043084a30e0722a5f97bf172161338d2f7106a8dfd387d0a", ""},
3: {primarySchema3, "65c2125ad0e12d02490cf2275f0067ef3c62a8522edf9a35ee8aa3f3c09b12e8", ""}, 3: {readDDL("primary_3.ddl"), "65c2125ad0e12d02490cf2275f0067ef3c62a8522edf9a35ee8aa3f3c09b12e8", ""},
4: {primarySchema4, "cb022156ab0e7aea39dd0c985428c43cae7d60e41ca8e9e5a84c774b3019d2ca", primaryMigration_3_4}, 4: {readDDL("primary_4.ddl"), "cb022156ab0e7aea39dd0c985428c43cae7d60e41ca8e9e5a84c774b3019d2ca", readMig("primary_migration_3_4.sql")},
5: {primarySchema5, "9d6217ba4a3503cfe090f72569367f95a413bb14e9effe49ffeabbf255bce8dd", primaryMigration_4_5}, 5: {readDDL("primary_5.ddl"), "9d6217ba4a3503cfe090f72569367f95a413bb14e9effe49ffeabbf255bce8dd", readMig("primary_migration_4_5.sql")},
6: {primarySchema6, "8e83d20bcd008082713f248ae8cd558335a37a37ce90bd8c86e782da640ee160", primaryMigration_5_6}, 6: {readDDL("primary_6.ddl"), "8e83d20bcd008082713f248ae8cd558335a37a37ce90bd8c86e782da640ee160", readMig("primary_migration_5_6.sql")},
7: {primarySchema7, "90d8dbc460afe025f9b74cda5c16bb8e58b178df275223bd2531907a8d8c36c3", primaryMigration_6_7}, 7: {readDDL("primary_7.ddl"), "90d8dbc460afe025f9b74cda5c16bb8e58b178df275223bd2531907a8d8c36c3", readMig("primary_migration_6_7.sql")},
8: {primarySchema8, "746f6005c7a573b8816e5993ecd1d949fe2552b0134ba63bab8b4d5b2b5058ad", primaryMigration_7_8}, 8: {readDDL("primary_8.ddl"), "746f6005c7a573b8816e5993ecd1d949fe2552b0134ba63bab8b4d5b2b5058ad", readMig("primary_migration_7_8.sql")},
} }
var PrimarySchemaVersion = len(PrimarySchema) - 1 var PrimarySchemaVersion = len(PrimarySchema) - 1
var RequestsSchema = map[int]Def{ var RequestsSchema = map[int]Def{
0: {"", "", ""}, 0: {"", "", ""},
1: {requestsSchema1, "ebb0a5748b605e8215437413b738279670190ca8159b6227cfc2aa13418b41e9", ""}, 1: {readDDL("requests_1.ddl"), "ebb0a5748b605e8215437413b738279670190ca8159b6227cfc2aa13418b41e9", ""},
} }
var RequestsSchemaVersion = len(RequestsSchema) - 1 var RequestsSchemaVersion = len(RequestsSchema) - 1
var LogsSchema = map[int]Def{ var LogsSchema = map[int]Def{
0: {"", "", ""}, 0: {"", "", ""},
1: {logsSchema1, "65fba477c04095effc3a8e1bb79fe7547b8e52e983f776f156266eddc4f201d7", ""}, 1: {readDDL("logs_1.ddl"), "65fba477c04095effc3a8e1bb79fe7547b8e52e983f776f156266eddc4f201d7", ""},
} }
var LogsSchemaVersion = len(LogsSchema) - 1 var LogsSchemaVersion = len(LogsSchema) - 1
func readDDL(name string) string {
data, err := assets.ReadFile(name)
if err != nil {
panic(err)
}
return string(data)
}
func readMig(name string) string {
data, err := assets.ReadFile(name)
if err != nil {
panic(err)
}
return string(data)
}