Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
alist-org
GitHub Repository: alist-org/alist
Path: blob/main/internal/db/db.go
1560 views
1
package db
2
3
import (
4
log "github.com/sirupsen/logrus"
5
6
"github.com/alist-org/alist/v3/internal/conf"
7
"github.com/alist-org/alist/v3/internal/model"
8
"gorm.io/gorm"
9
)
10
11
var db *gorm.DB
12
13
func Init(d *gorm.DB) {
14
db = d
15
err := AutoMigrate(new(model.Storage), new(model.User), new(model.Meta), new(model.SettingItem), new(model.SearchNode), new(model.TaskItem), new(model.SSHPublicKey), new(model.Role), new(model.Label), new(model.LabelFileBinding), new(model.ObjFile), new(model.Session))
16
if err != nil {
17
log.Fatalf("failed migrate database: %s", err.Error())
18
}
19
}
20
21
func AutoMigrate(dst ...interface{}) error {
22
var err error
23
if conf.Conf.Database.Type == "mysql" {
24
err = db.Set("gorm:table_options", "ENGINE=InnoDB CHARSET=utf8mb4").AutoMigrate(dst...)
25
} else {
26
err = db.AutoMigrate(dst...)
27
}
28
return err
29
}
30
31
func GetDb() *gorm.DB {
32
return db
33
}
34
35
func Close() {
36
log.Info("closing db")
37
sqlDB, err := db.DB()
38
if err != nil {
39
log.Errorf("failed to get db: %s", err.Error())
40
return
41
}
42
err = sqlDB.Close()
43
if err != nil {
44
log.Errorf("failed to close db: %s", err.Error())
45
return
46
}
47
}
48
49