ferry/cmd/migrate/server.go

60 lines
1.3 KiB
Go
Raw Normal View History

2020-07-13 20:33:20 +08:00
package migrate
import (
"ferry/database"
"ferry/global/orm"
"ferry/models/gorm"
"ferry/tools"
config2 "ferry/tools/config"
"fmt"
log "github.com/sirupsen/logrus"
"github.com/spf13/cobra"
)
var (
config string
mode string
StartCmd = &cobra.Command{
Use: "init",
Short: "initialize the database",
Run: func(cmd *cobra.Command, args []string) {
run()
},
}
)
func init() {
StartCmd.PersistentFlags().StringVarP(&config, "config", "c", "config/settings.yml", "Start server with provided configuration file")
StartCmd.PersistentFlags().StringVarP(&mode, "mode", "m", "dev", "server mode ; eg:dev,test,prod")
}
func run() {
usage := `start init`
fmt.Println(usage)
//1. 读取配置
config2.ConfigSetup(config)
//2. 设置日志
tools.InitLogger()
//3. 初始化数据库链接
database.Setup()
//4. 数据库迁移
_ = migrateModel()
log.Println("数据库结构初始化成功!")
//5. 数据初始化完成
2020-07-15 01:40:56 +08:00
//if err := system.InitDb(); err != nil {
// log.Fatal("数据库基础数据初始化失败!")
//}
2020-07-13 20:33:20 +08:00
usage = `数据库基础数据初始化成功`
fmt.Println(usage)
}
func migrateModel() error {
if config2.DatabaseConfig.Dbtype == "mysql" {
orm.Eloquent = orm.Eloquent.Set("gorm:table_options", "ENGINE=InnoDB CHARSET=utf8mb4")
}
return gorm.AutoMigrate(orm.Eloquent)
}