Newer
Older

Guilhem CARRON
committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package models
import (
"fmt"
"forge.grandlyon.com/web-et-numerique/llle_project/backoffice-server/internal/common"
"gorm.io/driver/mysql"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
)
type DataHandler struct {
db *gorm.DB
}
var (
dbUser = common.StringValueFromEnv("DATABASE_USER", "")
dbPassword = common.StringValueFromEnv("DATABASE_PASSWORD", "")
dbName = common.StringValueFromEnv("DATABASE_NAME", "")
dbHost = common.StringValueFromEnv("DATABASE_HOST", "")
)
// NewDataHandler init a DataHandler and returns a pointer to it
func NewDataHandler() *DataHandler {
var db *gorm.DB
var err error
if dbUser == "" || dbPassword == "" || dbName == "" {
db, err = gorm.Open(sqlite.Open("backoffice.db"), &gorm.Config{})
if err != nil {
panic("failed to connect database")
}
} else {
dsn := fmt.Sprintf("%v:%v@tcp(%v:3306)/%v?charset=utf8mb4&parseTime=True&loc=Local", dbUser, dbPassword, dbHost, dbName)
db, err = gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
panic("failed to connect database")
}
}
// Migrate the schema
db.AutoMigrate(&MonthlyInfo{})
db.AutoMigrate(&MonthlyNews{})
db.AutoMigrate(&Poll{})
return &DataHandler{db: db}
}