authorizer/server/db/user.go

75 lines
1.7 KiB
Go
Raw Normal View History

2021-07-12 18:22:16 +00:00
package db
import (
"log"
"golang.org/x/crypto/bcrypt"
"gorm.io/gorm"
"gorm.io/gorm/clause"
)
type User struct {
ID uint `gorm:"primaryKey"`
FirstName string
LastName string
Email string `gorm:"unique"`
Password string
SignupMethod string
EmailVerifiedAt int64
CreatedAt int64 `gorm:"autoCreateTime"`
UpdatedAt int64 `gorm:"autoUpdateTime"`
2021-07-14 07:16:48 +00:00
Image string
SignUpMethod string
2021-07-12 18:22:16 +00:00
}
func (user *User) BeforeSave(tx *gorm.DB) error {
// Modify current operation through tx.Statement, e.g:
2021-07-14 18:42:18 +00:00
if pw, err := bcrypt.GenerateFromPassword([]byte(user.Password), bcrypt.DefaultCost); err == nil {
2021-07-12 18:22:16 +00:00
tx.Statement.SetColumn("Password", pw)
}
return nil
}
// AddUser function to add user
func (mgr *manager) AddUser(user User) (User, error) {
2021-07-14 07:16:48 +00:00
result := mgr.db.Clauses(clause.OnConflict{UpdateAll: true, Columns: []clause.Column{{Name: "email"}}}).Create(&user)
2021-07-12 18:22:16 +00:00
if result.Error != nil {
log.Println(result.Error)
return user, result.Error
}
return user, nil
}
// GetUsers function to get all users
func (mgr *manager) GetUsers() ([]User, error) {
var users []User
result := mgr.db.Find(&users)
if result.Error != nil {
log.Println(result.Error)
return users, result.Error
}
return users, nil
}
func (mgr *manager) GetUserByEmail(email string) (User, error) {
var user User
result := mgr.db.Where("email = ?", email).First(&user)
if result.Error != nil {
return user, result.Error
}
return user, nil
}
func (mgr *manager) UpdateVerificationTime(verifiedAt int64, email string) error {
result := mgr.db.Model(&User{}).Where("email = ?", email).Update("email_verified_at", verifiedAt)
if result.Error != nil {
return result.Error
}
return nil
}