2022-01-21 07:23:30 +00:00
|
|
|
package sql
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/authorizerdev/authorizer/server/constants"
|
|
|
|
"github.com/authorizerdev/authorizer/server/db/models"
|
2022-01-25 05:27:40 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/graph/model"
|
2022-05-29 11:52:46 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/memorystore"
|
2022-01-21 07:23:30 +00:00
|
|
|
"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 == "" {
|
2022-05-31 02:44:03 +00:00
|
|
|
defaultRoles, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyDefaultRoles)
|
2022-05-29 11:52:46 +00:00
|
|
|
if err != nil {
|
|
|
|
return user, err
|
|
|
|
}
|
2022-05-31 02:44:03 +00:00
|
|
|
user.Roles = defaultRoles
|
2022-01-21 07:23:30 +00:00
|
|
|
}
|
|
|
|
|
2022-01-31 06:05:24 +00:00
|
|
|
user.CreatedAt = time.Now().Unix()
|
|
|
|
user.UpdatedAt = time.Now().Unix()
|
2022-01-21 07:23:30 +00:00
|
|
|
user.Key = user.ID
|
|
|
|
result := p.db.Clauses(
|
|
|
|
clause.OnConflict{
|
|
|
|
UpdateAll: true,
|
|
|
|
Columns: []clause.Column{{Name: "email"}},
|
|
|
|
}).Create(&user)
|
|
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
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 {
|
|
|
|
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 {
|
|
|
|
return result.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ListUsers to get list of users from database
|
2022-01-25 05:27:40 +00:00
|
|
|
func (p *provider) ListUsers(pagination model.Pagination) (*model.Users, error) {
|
2022-01-21 07:23:30 +00:00
|
|
|
var users []models.User
|
2022-01-25 05:27:40 +00:00
|
|
|
result := p.db.Limit(int(pagination.Limit)).Offset(int(pagination.Offset)).Order("created_at DESC").Find(&users)
|
2022-01-21 07:23:30 +00:00
|
|
|
if result.Error != nil {
|
2022-01-25 05:27:40 +00:00
|
|
|
return nil, result.Error
|
2022-01-21 07:23:30 +00:00
|
|
|
}
|
|
|
|
|
2022-01-25 05:27:40 +00:00
|
|
|
responseUsers := []*model.User{}
|
|
|
|
for _, user := range users {
|
|
|
|
responseUsers = append(responseUsers, user.AsAPIUser())
|
|
|
|
}
|
|
|
|
|
|
|
|
var total int64
|
|
|
|
totalRes := p.db.Model(&models.User{}).Count(&total)
|
|
|
|
if totalRes.Error != nil {
|
|
|
|
return nil, totalRes.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
paginationClone := pagination
|
|
|
|
paginationClone.Total = total
|
|
|
|
|
|
|
|
return &model.Users{
|
|
|
|
Pagination: &paginationClone,
|
|
|
|
Users: responseUsers,
|
|
|
|
}, nil
|
2022-01-21 07:23:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 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
|
|
|
|
}
|