mirror of
https://github.com/scroll-tech/scroll.git
synced 2026-01-14 16:37:56 -05:00
44 lines
848 B
Go
44 lines
848 B
Go
package utils
|
|
|
|
import (
|
|
"gorm.io/driver/postgres"
|
|
"gorm.io/gorm"
|
|
"gorm.io/gorm/logger"
|
|
|
|
"scroll-tech/bridge/internal/config"
|
|
)
|
|
|
|
// InitDB init the db handler
|
|
func InitDB(config *config.DBConfig) (*gorm.DB, error) {
|
|
db, err := gorm.Open(postgres.Open(config.DSN), &gorm.Config{
|
|
Logger: logger.Default.LogMode(logger.Info),
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
sqlDB, err := db.DB()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
sqlDB.SetMaxOpenConns(config.MaxOpenNum)
|
|
sqlDB.SetMaxIdleConns(config.MaxIdleNum)
|
|
|
|
if err = sqlDB.Ping(); err != nil {
|
|
return nil, err
|
|
}
|
|
return db, nil
|
|
}
|
|
|
|
// CloseDB close the db handler. notice the db handler only can close when then program exit.
|
|
func CloseDB(db *gorm.DB) error {
|
|
sqlDB, err := db.DB()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if err := sqlDB.Close(); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|