2021-07-12 18:22:16 +00:00
|
|
|
package db
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"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 18:43:19 +00:00
|
|
|
Image string
|
2021-09-20 05:06:26 +00:00
|
|
|
Roles string
|
2021-07-12 18:22:16 +00:00
|
|
|
}
|
|
|
|
|
2021-07-18 03:55:20 +00:00
|
|
|
// SaveUser function to add user even with email conflict
|
2021-07-17 16:29:50 +00:00
|
|
|
func (mgr *manager) SaveUser(user User) (User, error) {
|
2021-07-18 03:55:20 +00:00
|
|
|
result := mgr.db.Clauses(
|
|
|
|
clause.OnConflict{
|
|
|
|
UpdateAll: true,
|
|
|
|
Columns: []clause.Column{{Name: "email"}},
|
|
|
|
}).Create(&user)
|
|
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
log.Println(result.Error)
|
|
|
|
return user, result.Error
|
|
|
|
}
|
|
|
|
return user, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// UpdateUser function to update user with ID conflict
|
|
|
|
func (mgr *manager) UpdateUser(user User) (User, error) {
|
|
|
|
result := mgr.db.Clauses(
|
|
|
|
clause.OnConflict{
|
|
|
|
UpdateAll: true,
|
|
|
|
Columns: []clause.Column{{Name: "id"}},
|
|
|
|
}).Create(&user)
|
2021-07-17 16:29:50 +00:00
|
|
|
|
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
|
|
|
|
}
|
2021-07-13 20:06:11 +00:00
|
|
|
|
2021-07-15 12:02:55 +00:00
|
|
|
func (mgr *manager) UpdateVerificationTime(verifiedAt int64, id uint) error {
|
|
|
|
user := &User{
|
|
|
|
ID: id,
|
|
|
|
}
|
|
|
|
result := mgr.db.Model(&user).Where("id = ?", id).Update("email_verified_at", verifiedAt)
|
2021-07-13 20:06:11 +00:00
|
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
return result.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2021-08-06 13:47:52 +00:00
|
|
|
|
|
|
|
func (mgr *manager) DeleteUser(email string) error {
|
|
|
|
var user User
|
|
|
|
result := mgr.db.Where("email = ?", email).Delete(&user)
|
|
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
log.Println(`Error deleting user:`, result.Error)
|
|
|
|
return result.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|