mirror of
https://github.com/muety/wakapi.git
synced 2023-08-10 21:12:56 +03:00
b6812ddc3a
fix: cascade for alias user foreign key constraint
59 lines
1.4 KiB
Go
59 lines
1.4 KiB
Go
package migrations
|
|
|
|
import (
|
|
"github.com/emvi/logbuch"
|
|
"github.com/muety/wakapi/config"
|
|
"github.com/muety/wakapi/models"
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
func init() {
|
|
const name = "20210202-fix_cascade_for_alias_user_constraint"
|
|
|
|
f := migrationFunc{
|
|
name: name,
|
|
f: func(db *gorm.DB, cfg *config.Config) error {
|
|
migrator := db.Migrator()
|
|
|
|
if cfg.Db.Dialect == config.SQLDialectSqlite {
|
|
// see 20201106_migration_cascade_constraints
|
|
logbuch.Info("not attempting to drop and regenerate constraints on sqlite")
|
|
return nil
|
|
}
|
|
|
|
if !migrator.HasTable(&models.KeyStringValue{}) {
|
|
logbuch.Info("key-value table not yet existing")
|
|
return nil
|
|
}
|
|
|
|
condition := "key = ?"
|
|
if cfg.Db.Dialect == config.SQLDialectMysql {
|
|
condition = "`key` = ?"
|
|
}
|
|
lookupResult := db.Where(condition, name).First(&models.KeyStringValue{})
|
|
if lookupResult.Error == nil && lookupResult.RowsAffected > 0 {
|
|
logbuch.Info("no need to migrate '%s'", name)
|
|
return nil
|
|
}
|
|
|
|
if migrator.HasConstraint(&models.Alias{}, "fk_aliases_user") {
|
|
logbuch.Info("dropping constraint 'fk_aliases_user'")
|
|
if err := migrator.DropConstraint(&models.Alias{}, "fk_aliases_user"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
if err := db.Create(&models.KeyStringValue{
|
|
Key: name,
|
|
Value: "done",
|
|
}).Error; err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
},
|
|
}
|
|
|
|
registerPreMigration(f)
|
|
}
|