3x-ui/database/db.go

107 lines
1.6 KiB
Go
Raw Normal View History

2023-02-09 22:18:06 +03:00
package database
import (
"io/fs"
"os"
"path"
"x-ui/config"
"x-ui/database/model"
2023-02-16 18:58:20 +03:00
"x-ui/xray"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
"gorm.io/gorm/logger"
2023-02-09 22:18:06 +03:00
)
var db *gorm.DB
func initUser() error {
err := db.AutoMigrate(&model.User{})
if err != nil {
return err
}
var count int64
err = db.Model(&model.User{}).Count(&count).Error
if err != nil {
return err
}
if count == 0 {
user := &model.User{
Username: "admin",
Password: "admin",
LoginSecret: "",
2023-02-09 22:18:06 +03:00
}
return db.Create(user).Error
}
return nil
}
func initInbound() error {
return db.AutoMigrate(&model.Inbound{})
}
func initSetting() error {
return db.AutoMigrate(&model.Setting{})
}
2023-02-28 22:54:29 +03:00
func initInboundClientIps() error {
return db.AutoMigrate(&model.InboundClientIps{})
}
2023-02-09 22:18:06 +03:00
func initClientTraffic() error {
return db.AutoMigrate(&xray.ClientTraffic{})
}
func InitDB(dbPath string) error {
dir := path.Dir(dbPath)
err := os.MkdirAll(dir, fs.ModeDir)
if err != nil {
return err
}
var gormLogger logger.Interface
if config.IsDebug() {
gormLogger = logger.Default
} else {
gormLogger = logger.Discard
}
c := &gorm.Config{
Logger: gormLogger,
}
db, err = gorm.Open(sqlite.Open(dbPath), c)
if err != nil {
return err
}
err = initUser()
if err != nil {
return err
}
err = initInbound()
if err != nil {
return err
}
err = initSetting()
if err != nil {
return err
}
2023-02-28 22:54:29 +03:00
err = initInboundClientIps()
if err != nil {
return err
}
2023-02-09 22:18:06 +03:00
err = initClientTraffic()
if err != nil {
return err
}
2023-04-10 14:03:50 +03:00
2023-02-09 22:18:06 +03:00
return nil
}
func GetDB() *gorm.DB {
return db
}
func IsNotFound(err error) bool {
return err == gorm.ErrRecordNotFound
}