Michael Mayer 260cca91fe Backend: Refactor entity package
Signed-off-by: Michael Mayer <michael@liquidbytes.net>
2020-04-30 20:07:03 +02:00

90 lines
1.4 KiB
Go

package entity
import (
"fmt"
"sync"
"time"
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/mysql"
)
var dbProvider DbProvider
type DbProvider interface {
Db() *gorm.DB
}
// SetDbProvider sets the provider to get a gorm db connection.
func SetDbProvider(provider DbProvider) {
dbProvider = provider
}
// Db() returns a database connection.
func Db() *gorm.DB {
return dbProvider.Db()
}
// Db() returns an unscoped database connection.
func Unscoped() *gorm.DB {
return Db().Unscoped()
}
type Gorm struct {
Driver string
Dsn string
once sync.Once
db *gorm.DB
}
// Db returns the gorm db connection.
func (g *Gorm) Db() *gorm.DB {
g.once.Do(g.Connect)
if g.db == nil {
log.Fatal("entity: database not connected")
}
return g.db
}
// Connect creates a new gorm db connection.
func (g *Gorm) Connect() {
db, err := gorm.Open(g.Driver, g.Dsn)
if err != nil || db == nil {
for i := 1; i <= 12; i++ {
fmt.Printf("gorm.Open(%s, %s) %d\n", g.Driver, g.Dsn, i)
db, err = gorm.Open(g.Driver, g.Dsn)
if db != nil && err == nil {
break
} else {
time.Sleep(5 * time.Second)
}
}
if err != nil || db == nil {
fmt.Println(err)
log.Fatal(err)
}
}
db.LogMode(false)
db.SetLogger(log)
g.db = db
}
// Close closes the gorm db connection.
func (g *Gorm) Close() {
if g.db != nil {
if err := g.db.Close(); err != nil {
log.Fatal(err)
}
g.db = nil
}
}