Files
OpenList/bootstrap/model.go

75 lines
1.8 KiB
Go
Raw Normal View History

2021-03-04 23:50:51 +08:00
package bootstrap
import (
2021-03-16 23:15:37 +08:00
"fmt"
2021-03-04 23:50:51 +08:00
"github.com/Xhofe/alist/conf"
"github.com/Xhofe/alist/server/models"
"github.com/Xhofe/alist/utils"
log "github.com/sirupsen/logrus"
2021-03-16 23:15:37 +08:00
"gorm.io/driver/mysql"
2021-03-04 23:50:51 +08:00
"gorm.io/driver/sqlite"
"gorm.io/gorm"
2021-03-16 23:15:37 +08:00
"gorm.io/gorm/schema"
2021-03-08 20:26:02 +08:00
"strings"
2021-03-04 23:50:51 +08:00
)
func InitModel() bool {
log.Infof("初始化数据库...")
2021-03-16 23:15:37 +08:00
dbConfig := conf.Conf.Database
switch dbConfig.Type {
2021-03-05 21:07:45 +08:00
case "sqlite3":
{
2021-03-16 23:15:37 +08:00
if !(strings.HasSuffix(dbConfig.DBFile, ".db") && len(dbConfig.DBFile) > 3) {
2021-03-08 20:26:02 +08:00
log.Errorf("db名称不正确.")
return false
}
2021-03-16 23:15:37 +08:00
needMigrate := !utils.Exists(dbConfig.DBFile)
db, err := gorm.Open(sqlite.Open(dbConfig.DBFile), &gorm.Config{
NamingStrategy: schema.NamingStrategy{
TablePrefix: dbConfig.TablePrefix,
},
})
2021-03-05 21:07:45 +08:00
if err != nil {
log.Errorf("连接数据库出现错误:%s", err.Error())
2021-03-04 23:50:51 +08:00
return false
}
2021-03-05 21:07:45 +08:00
conf.DB = db
if needMigrate {
log.Infof("迁移数据库...")
err = conf.DB.AutoMigrate(&models.File{})
if err != nil {
log.Errorf("数据库迁移失败:%s", err.Error())
return false
}
2021-03-16 23:15:37 +08:00
//models.BuildTreeAll()
}
return true
}
case "mysql":
{
dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8mb4&parseTime=True&loc=Local",
dbConfig.User, dbConfig.Password, dbConfig.Host, dbConfig.Port, dbConfig.Name)
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{
NamingStrategy: schema.NamingStrategy{
TablePrefix: dbConfig.TablePrefix,
},
})
if err != nil {
log.Errorf("连接数据库出现错误:%s", err.Error())
return false
}
conf.DB = db
log.Infof("迁移数据库...")
err = conf.DB.AutoMigrate(&models.File{})
if err != nil {
log.Errorf("数据库迁移失败:%s", err.Error())
return false
2021-03-05 21:07:45 +08:00
}
return true
2021-03-04 23:50:51 +08:00
}
default:
2021-03-16 23:15:37 +08:00
log.Errorf("不支持的数据库类型:%s", dbConfig.Type)
2021-03-04 23:50:51 +08:00
return false
}
}