|  | 
| 1 | 1 | package internal | 
| 2 | 2 | 
 | 
| 3 | 3 | import ( | 
|  | 4 | +	"github.com/flipped-aurora/gin-vue-admin/server/config" | 
| 4 | 5 | 	"github.com/flipped-aurora/gin-vue-admin/server/global" | 
| 5 | 6 | 	"gorm.io/gorm" | 
| 6 | 7 | 	"gorm.io/gorm/logger" | 
| 7 | 8 | 	"gorm.io/gorm/schema" | 
|  | 9 | +	"log" | 
|  | 10 | +	"os" | 
|  | 11 | +	"time" | 
| 8 | 12 | ) | 
| 9 | 13 | 
 | 
| 10 |  | -type DBBASE interface { | 
| 11 |  | -	GetLogMode() string | 
| 12 |  | -} | 
| 13 |  | - | 
| 14 | 14 | var Gorm = new(_gorm) | 
| 15 | 15 | 
 | 
| 16 | 16 | type _gorm struct{} | 
| 17 | 17 | 
 | 
| 18 | 18 | // Config gorm 自定义配置 | 
| 19 | 19 | // Author [SliverHorn](https://github.com/SliverHorn) | 
| 20 | 20 | func (g *_gorm) Config(prefix string, singular bool) *gorm.Config { | 
| 21 |  | -	config := &gorm.Config{ | 
| 22 |  | -		NamingStrategy: schema.NamingStrategy{ | 
| 23 |  | -			TablePrefix:   prefix, | 
| 24 |  | -			SingularTable: singular, | 
| 25 |  | -		}, | 
| 26 |  | -		DisableForeignKeyConstraintWhenMigrating: true, | 
| 27 |  | -	} | 
| 28 |  | -	_default := NewZapLogger() | 
| 29 |  | -	var logMode DBBASE | 
|  | 21 | +	var general config.GeneralDB | 
| 30 | 22 | 	switch global.GVA_CONFIG.System.DbType { | 
| 31 | 23 | 	case "mysql": | 
| 32 |  | -		logMode = &global.GVA_CONFIG.Mysql | 
|  | 24 | +		general = global.GVA_CONFIG.Mysql.GeneralDB | 
| 33 | 25 | 	case "pgsql": | 
| 34 |  | -		logMode = &global.GVA_CONFIG.Pgsql | 
|  | 26 | +		general = global.GVA_CONFIG.Pgsql.GeneralDB | 
| 35 | 27 | 	case "oracle": | 
| 36 |  | -		logMode = &global.GVA_CONFIG.Oracle | 
|  | 28 | +		general = global.GVA_CONFIG.Oracle.GeneralDB | 
|  | 29 | +	case "sqlite": | 
|  | 30 | +		general = global.GVA_CONFIG.Sqlite.GeneralDB | 
|  | 31 | +	case "mssql": | 
|  | 32 | +		general = global.GVA_CONFIG.Mssql.GeneralDB | 
| 37 | 33 | 	default: | 
| 38 |  | -		logMode = &global.GVA_CONFIG.Mysql | 
|  | 34 | +		general = global.GVA_CONFIG.Mysql.GeneralDB | 
| 39 | 35 | 	} | 
| 40 |  | - | 
| 41 |  | -	switch logMode.GetLogMode() { | 
| 42 |  | -	case "silent", "Silent": | 
| 43 |  | -		config.Logger = _default.LogMode(logger.Silent) | 
| 44 |  | -	case "error", "Error": | 
| 45 |  | -		config.Logger = _default.LogMode(logger.Error) | 
| 46 |  | -	case "warn", "Warn": | 
| 47 |  | -		config.Logger = _default.LogMode(logger.Warn) | 
| 48 |  | -	case "info", "Info": | 
| 49 |  | -		config.Logger = _default.LogMode(logger.Info) | 
| 50 |  | -	default: | 
| 51 |  | -		config.Logger = _default.LogMode(logger.Info) | 
|  | 36 | +	return &gorm.Config{ | 
|  | 37 | +		Logger: logger.New(NewWriter(general, log.New(os.Stdout, "\r\n", log.LstdFlags)), logger.Config{ | 
|  | 38 | +			SlowThreshold: 200 * time.Millisecond, | 
|  | 39 | +			LogLevel:      general.LogLevel(), | 
|  | 40 | +			Colorful:      true, | 
|  | 41 | +		}), | 
|  | 42 | +		NamingStrategy: schema.NamingStrategy{ | 
|  | 43 | +			TablePrefix:   prefix, | 
|  | 44 | +			SingularTable: singular, | 
|  | 45 | +		}, | 
|  | 46 | +		DisableForeignKeyConstraintWhenMigrating: true, | 
| 52 | 47 | 	} | 
| 53 |  | -	return config | 
| 54 | 48 | } | 
0 commit comments