102 lines
2.3 KiB
Go
102 lines
2.3 KiB
Go
![]() |
package sql
|
||
|
|
||
|
import (
|
||
|
"log"
|
||
|
"strings"
|
||
|
"time"
|
||
|
|
||
|
"github.com/authorizerdev/authorizer/server/constants"
|
||
|
"github.com/authorizerdev/authorizer/server/db/models"
|
||
|
"github.com/authorizerdev/authorizer/server/envstore"
|
||
|
"github.com/google/uuid"
|
||
|
"gorm.io/gorm/clause"
|
||
|
)
|
||
|
|
||
|
// AddUser to save user information in database
|
||
|
func (p *provider) AddUser(user models.User) (models.User, error) {
|
||
|
if user.ID == "" {
|
||
|
user.ID = uuid.New().String()
|
||
|
}
|
||
|
|
||
|
if user.Roles == "" {
|
||
|
user.Roles = strings.Join(envstore.EnvInMemoryStoreObj.GetSliceStoreEnvVariable(constants.EnvKeyDefaultRoles), ",")
|
||
|
}
|
||
|
|
||
|
user.Key = user.ID
|
||
|
result := p.db.Clauses(
|
||
|
clause.OnConflict{
|
||
|
UpdateAll: true,
|
||
|
Columns: []clause.Column{{Name: "email"}},
|
||
|
}).Create(&user)
|
||
|
|
||
|
if result.Error != nil {
|
||
|
log.Println("error adding user:", result.Error)
|
||
|
return user, result.Error
|
||
|
}
|
||
|
|
||
|
return user, nil
|
||
|
}
|
||
|
|
||
|
// UpdateUser to update user information in database
|
||
|
func (p *provider) UpdateUser(user models.User) (models.User, error) {
|
||
|
user.UpdatedAt = time.Now().Unix()
|
||
|
|
||
|
result := p.db.Save(&user)
|
||
|
|
||
|
if result.Error != nil {
|
||
|
log.Println("error updating user:", result.Error)
|
||
|
return user, result.Error
|
||
|
}
|
||
|
|
||
|
return user, nil
|
||
|
}
|
||
|
|
||
|
// DeleteUser to delete user information from database
|
||
|
func (p *provider) DeleteUser(user models.User) error {
|
||
|
result := p.db.Delete(&user)
|
||
|
|
||
|
if result.Error != nil {
|
||
|
log.Println(`error deleting user:`, result.Error)
|
||
|
return result.Error
|
||
|
}
|
||
|
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
// ListUsers to get list of users from database
|
||
|
func (p *provider) ListUsers() ([]models.User, error) {
|
||
|
var users []models.User
|
||
|
result := p.db.Find(&users)
|
||
|
if result.Error != nil {
|
||
|
log.Println("error getting users:", result.Error)
|
||
|
return users, result.Error
|
||
|
}
|
||
|
|
||
|
return users, nil
|
||
|
}
|
||
|
|
||
|
// GetUserByEmail to get user information from database using email address
|
||
|
func (p *provider) GetUserByEmail(email string) (models.User, error) {
|
||
|
var user models.User
|
||
|
result := p.db.Where("email = ?", email).First(&user)
|
||
|
|
||
|
if result.Error != nil {
|
||
|
return user, result.Error
|
||
|
}
|
||
|
|
||
|
return user, nil
|
||
|
}
|
||
|
|
||
|
// GetUserByID to get user information from database using user ID
|
||
|
func (p *provider) GetUserByID(id string) (models.User, error) {
|
||
|
var user models.User
|
||
|
|
||
|
result := p.db.Where("id = ?", id).First(&user)
|
||
|
|
||
|
if result.Error != nil {
|
||
|
return user, result.Error
|
||
|
}
|
||
|
|
||
|
return user, nil
|
||
|
}
|