feat: add gen model
This commit is contained in:
@@ -9,7 +9,7 @@ import (
|
||||
"github.com/spf13/viper"
|
||||
)
|
||||
|
||||
func GetDB(cfgFile string) (*sql.DB, error) {
|
||||
func GetDB(cfgFile string) (*sql.DB, *Config, error) {
|
||||
var conf Config
|
||||
v := viper.New()
|
||||
v.SetConfigType("toml")
|
||||
@@ -17,23 +17,23 @@ func GetDB(cfgFile string) (*sql.DB, error) {
|
||||
v.AddConfigPath(".")
|
||||
|
||||
if err := v.ReadInConfig(); err != nil {
|
||||
return nil, errors.Wrap(err, "read config file")
|
||||
return nil, &conf, errors.Wrap(err, "read config file")
|
||||
}
|
||||
|
||||
if err := v.UnmarshalKey(DefaultPrefix, &conf); err != nil {
|
||||
return nil, errors.Wrap(err, "unmarshal config")
|
||||
return nil, &conf, errors.Wrap(err, "unmarshal config")
|
||||
}
|
||||
|
||||
log.Debugf("connect postgres with dsn: '%s'", conf.DSN())
|
||||
db, err := sql.Open("postgres", conf.DSN())
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "connect database")
|
||||
return nil, &conf, errors.Wrap(err, "connect database")
|
||||
}
|
||||
|
||||
if err := db.Ping(); err != nil {
|
||||
db.Close()
|
||||
return nil, errors.Wrap(err, "ping database")
|
||||
return nil, &conf, errors.Wrap(err, "ping database")
|
||||
}
|
||||
|
||||
return db, err
|
||||
return db, &conf, err
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user