mirror of
https://github.com/xiaoxinpro/nginx-proxy-manager-zh.git
synced 2025-01-23 05:18:12 -05:00
81 lines
1.8 KiB
Go
81 lines
1.8 KiB
Go
package database
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
"npm/internal/config"
|
|
"npm/internal/logger"
|
|
|
|
"github.com/glebarez/sqlite"
|
|
"github.com/rotisserie/eris"
|
|
"gorm.io/driver/mysql"
|
|
"gorm.io/driver/postgres"
|
|
"gorm.io/gorm"
|
|
gormlogger "gorm.io/gorm/logger"
|
|
"gorm.io/gorm/schema"
|
|
)
|
|
|
|
var dbInstance *gorm.DB
|
|
|
|
// NewDB creates a new connection
|
|
func NewDB() {
|
|
logger.Info("Creating new DB instance using %s", strings.ToLower(config.Configuration.DB.Driver))
|
|
db, err := connect()
|
|
if err != nil {
|
|
logger.Error("DatabaseConnectError", err)
|
|
} else if db != nil {
|
|
dbInstance = db
|
|
}
|
|
}
|
|
|
|
// GetDB returns an existing or new instance
|
|
func GetDB() *gorm.DB {
|
|
if dbInstance == nil {
|
|
NewDB()
|
|
}
|
|
return dbInstance
|
|
}
|
|
|
|
// SetDB will set the dbOnstance to this
|
|
// Used by unit testing to set the db to a mock database
|
|
func SetDB(db *gorm.DB) {
|
|
dbInstance = db
|
|
}
|
|
|
|
func connect() (*gorm.DB, error) {
|
|
var d gorm.Dialector
|
|
dsn := config.Configuration.DB.GetGormConnectURL()
|
|
switch strings.ToLower(config.Configuration.DB.Driver) {
|
|
|
|
case config.DatabaseSqlite:
|
|
// autocreate(dsn)
|
|
d = sqlite.Open(dsn)
|
|
|
|
case config.DatabasePostgres:
|
|
d = postgres.Open(dsn)
|
|
|
|
case config.DatabaseMysql:
|
|
d = mysql.Open(dsn)
|
|
|
|
default:
|
|
return nil, eris.New(fmt.Sprintf("Database driver %s is not supported. Valid options are: %s, %s or %s", config.Configuration.DB.Driver, config.DatabaseSqlite, config.DatabasePostgres, config.DatabaseMysql))
|
|
}
|
|
|
|
// see: https://gorm.io/docs/gorm_config.html
|
|
cfg := gorm.Config{
|
|
NamingStrategy: schema.NamingStrategy{
|
|
SingularTable: true,
|
|
NoLowerCase: true,
|
|
},
|
|
PrepareStmt: false,
|
|
}
|
|
|
|
// Silence gorm query errors unless when not in debug mode
|
|
if config.GetLogLevel() != logger.DebugLevel {
|
|
cfg.Logger = gormlogger.Default.LogMode(gormlogger.Silent)
|
|
}
|
|
|
|
return gorm.Open(d, &cfg)
|
|
}
|