alist/internal/db/db.go

45 lines
1.2 KiB
Go
Raw Normal View History

2022-06-25 13:36:35 +00:00
package db
2022-06-09 09:11:46 +00:00
import (
"fmt"
2022-08-03 06:26:59 +00:00
"log"
"github.com/alist-org/alist/v3/internal/conf"
2022-06-14 11:44:25 +00:00
"github.com/alist-org/alist/v3/internal/model"
2022-06-09 09:11:46 +00:00
"gorm.io/gorm"
)
var db *gorm.DB
2022-06-14 11:44:25 +00:00
2022-06-16 08:06:10 +00:00
func Init(d *gorm.DB) {
db = d
var err error
switch conf.Conf.Database.Type {
case "sqlite3":
err = AutoMigrate(new(model.Storage), new(model.User), new(model.Meta), new(model.SettingItem), new(model.SearchNode))
case "mysql":
err = AutoMigrate(new(model.Storage), new(model.User), new(model.Meta), new(model.SettingItem), new(model.SearchNodeMySQL))
case "postgres":
err = AutoMigrate(new(model.Storage), new(model.User), new(model.Meta), new(model.SettingItem), new(model.SearchNode))
if err == nil {
db.Exec("CREATE EXTENSION pg_trgm;")
db.Exec("CREATE EXTENSION btree_gin;")
tableName := fmt.Sprintf("%ssearch_nodes", conf.Conf.Database.TablePrefix)
db.Exec(fmt.Sprintf("CREATE INDEX idx_%s_name ON %s USING GIN (name);", tableName, tableName))
}
}
if err != nil {
log.Fatalf("failed migrate database: %s", err.Error())
}
}
func AutoMigrate(dst ...interface{}) error {
var err error
if conf.Conf.Database.Type == "mysql" {
err = db.Set("gorm:table_options", "ENGINE=InnoDB CHARSET=utf8mb4").AutoMigrate(dst...)
} else {
err = db.AutoMigrate(dst...)
2022-06-16 08:06:10 +00:00
}
return err
2022-06-14 11:44:25 +00:00
}