// Package that provides the functionality to open, close and use a database package database import ( "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/postgres" _ "github.com/jinzhu/gorm/dialects/sqlite" "github.com/genofire/hs_master-kss-monolith/lib/log" ) // Database connection for writing purposes var Write *gorm.DB // Database connection for reading purposes var Read *gorm.DB // Configuration files var ( config *Config runtime []interface{} ) // Configuration of the database connection type Config struct { // Type of the database (currently supports sqlite and postgres) Type string // Connection configuration Connection string // Create another connection for reading only ReadConnection string // Enable logging of the generated sql string Logging bool } // Function to open a database and set the given configuration func Open(c Config) (err error) { writeLog := log.Log.WithField("db", "write") config = &c Write, err = gorm.Open(config.Type, config.Connection) if err != nil { return } Write.SingularTable(true) Write.LogMode(c.Logging) Write.SetLogger(writeLog) Write.Callback().Create().Remove("gorm:update_time_stamp") Write.Callback().Update().Remove("gorm:update_time_stamp") if len(config.ReadConnection) > 0 { readLog := log.Log.WithField("db", "read") Read, err = gorm.Open(config.Type, config.ReadConnection) if err != nil { return } Read.SingularTable(true) Read.LogMode(c.Logging) Read.SetLogger(readLog) Read.Callback().Create().Remove("gorm:update_time_stamp") Read.Callback().Update().Remove("gorm:update_time_stamp") } else { Read = Write } Write.AutoMigrate(runtime...) return } // Function to safely close the database func Close() { Write.Close() if len(config.ReadConnection) > 0 { Read.Close() } } // Function to add a model to the runtime func AddModel(m interface{}) { runtime = append(runtime, m) }