2023-04-22 12:39:27 +00:00
|
|
|
package model
|
|
|
|
|
|
|
|
import (
|
|
|
|
"gorm.io/driver/mysql"
|
|
|
|
"gorm.io/driver/sqlite"
|
|
|
|
"gorm.io/gorm"
|
2023-04-22 13:14:09 +00:00
|
|
|
"one-api/common"
|
2023-04-22 12:39:27 +00:00
|
|
|
"os"
|
2023-08-12 02:05:25 +00:00
|
|
|
"time"
|
2023-04-22 12:39:27 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var DB *gorm.DB
|
|
|
|
|
|
|
|
func createRootAccountIfNeed() error {
|
|
|
|
var user User
|
|
|
|
//if user.Status != common.UserStatusEnabled {
|
|
|
|
if err := DB.First(&user).Error; err != nil {
|
|
|
|
common.SysLog("no user exists, create a root user for you: username is root, password is 123456")
|
|
|
|
hashedPassword, err := common.Password2Hash("123456")
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
rootUser := User{
|
|
|
|
Username: "root",
|
|
|
|
Password: hashedPassword,
|
|
|
|
Role: common.RoleRootUser,
|
|
|
|
Status: common.UserStatusEnabled,
|
|
|
|
DisplayName: "Root User",
|
2023-04-26 13:40:56 +00:00
|
|
|
AccessToken: common.GetUUID(),
|
2023-05-21 02:05:34 +00:00
|
|
|
Quota: 100000000,
|
2023-04-22 12:39:27 +00:00
|
|
|
}
|
|
|
|
DB.Create(&rootUser)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func CountTable(tableName string) (num int64) {
|
|
|
|
DB.Table(tableName).Count(&num)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func InitDB() (err error) {
|
|
|
|
var db *gorm.DB
|
|
|
|
if os.Getenv("SQL_DSN") != "" {
|
|
|
|
// Use MySQL
|
2023-06-21 17:12:28 +00:00
|
|
|
common.SysLog("using MySQL as database")
|
2023-04-22 12:39:27 +00:00
|
|
|
db, err = gorm.Open(mysql.Open(os.Getenv("SQL_DSN")), &gorm.Config{
|
|
|
|
PrepareStmt: true, // precompile SQL
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
// Use SQLite
|
2023-06-21 17:12:28 +00:00
|
|
|
common.SysLog("SQL_DSN not set, using SQLite as database")
|
2023-04-23 10:24:11 +00:00
|
|
|
common.UsingSQLite = true
|
2023-04-22 12:39:27 +00:00
|
|
|
db, err = gorm.Open(sqlite.Open(common.SQLitePath), &gorm.Config{
|
|
|
|
PrepareStmt: true, // precompile SQL
|
|
|
|
})
|
|
|
|
}
|
2023-06-22 02:59:01 +00:00
|
|
|
common.SysLog("database connected")
|
2023-04-22 12:39:27 +00:00
|
|
|
if err == nil {
|
2023-08-12 10:10:15 +00:00
|
|
|
if common.DebugEnabled {
|
|
|
|
db = db.Debug()
|
|
|
|
}
|
2023-04-22 12:39:27 +00:00
|
|
|
DB = db
|
2023-08-12 02:05:25 +00:00
|
|
|
sqlDB, err := DB.DB()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
sqlDB.SetMaxIdleConns(common.GetOrDefault("SQL_MAX_IDLE_CONNS", 10))
|
|
|
|
sqlDB.SetMaxOpenConns(common.GetOrDefault("SQL_MAX_OPEN_CONNS", 100))
|
|
|
|
sqlDB.SetConnMaxLifetime(time.Second * time.Duration(common.GetOrDefault("SQL_MAX_LIFETIME", 60)))
|
|
|
|
|
2023-06-21 16:52:27 +00:00
|
|
|
if !common.IsMasterNode {
|
|
|
|
return nil
|
|
|
|
}
|
2023-08-12 02:05:25 +00:00
|
|
|
err = db.AutoMigrate(&Channel{})
|
2023-04-22 12:39:27 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-04-23 04:43:10 +00:00
|
|
|
err = db.AutoMigrate(&Token{})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-04-22 12:39:27 +00:00
|
|
|
err = db.AutoMigrate(&User{})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
err = db.AutoMigrate(&Option{})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-04-26 09:02:26 +00:00
|
|
|
err = db.AutoMigrate(&Redemption{})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-06-07 15:26:00 +00:00
|
|
|
err = db.AutoMigrate(&Ability{})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-06-10 08:04:04 +00:00
|
|
|
err = db.AutoMigrate(&Log{})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-06-22 02:59:01 +00:00
|
|
|
common.SysLog("database migrated")
|
2023-04-22 12:39:27 +00:00
|
|
|
err = createRootAccountIfNeed()
|
|
|
|
return err
|
|
|
|
} else {
|
|
|
|
common.FatalLog(err)
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
func CloseDB() error {
|
|
|
|
sqlDB, err := DB.DB()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
err = sqlDB.Close()
|
|
|
|
return err
|
|
|
|
}
|