authorizer/server/db/db.go

58 lines
1.3 KiB
Go
Raw Normal View History

2021-07-12 18:22:16 +00:00
package db
import (
"log"
"github.com/yauthdev/yauth/server/constants"
"github.com/yauthdev/yauth/server/enum"
"gorm.io/driver/mysql"
"gorm.io/driver/postgres"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
"gorm.io/gorm/schema"
)
type Manager interface {
SaveUser(user User) (User, error)
UpdateUser(user User) (User, error)
2021-07-12 18:22:16 +00:00
GetUsers() ([]User, error)
GetUserByEmail(email string) (User, error)
2021-07-15 12:02:55 +00:00
UpdateVerificationTime(verifiedAt int64, id uint) error
2021-07-12 18:22:16 +00:00
AddVerification(verification Verification) (Verification, error)
GetVerificationByToken(token string) (Verification, error)
DeleteToken(email string) error
2021-07-12 18:22:16 +00:00
}
type manager struct {
db *gorm.DB
}
var Mgr Manager
func init() {
var db *gorm.DB
var err error
ormConfig := &gorm.Config{
NamingStrategy: schema.NamingStrategy{
TablePrefix: "yauth_",
},
}
if constants.DB_TYPE == enum.Postgres.String() {
2021-07-12 18:22:16 +00:00
db, err = gorm.Open(postgres.Open(constants.DB_URL), ormConfig)
}
if constants.DB_TYPE == enum.Mysql.String() {
2021-07-12 18:22:16 +00:00
db, err = gorm.Open(mysql.Open(constants.DB_URL), ormConfig)
}
if constants.DB_TYPE == enum.Sqlite.String() {
2021-07-12 18:22:16 +00:00
db, err = gorm.Open(sqlite.Open(constants.DB_URL), ormConfig)
}
if err != nil {
log.Fatal("Failed to init db:", err)
} else {
db.AutoMigrate(&User{}, &Verification{})
}
Mgr = &manager{db: db}
}