mirror of
https://github.com/hazemKrimi/crimson-vault.git
synced 2026-05-01 18:20:27 +00:00
200 lines
4.0 KiB
Go
200 lines
4.0 KiB
Go
package models
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/google/uuid"
|
|
|
|
"github.com/hazemKrimi/crimson-vault/internal/lib"
|
|
"github.com/hazemKrimi/crimson-vault/internal/types"
|
|
)
|
|
|
|
func (db *DB) CreateUser(body types.CreateUserRequestBody) (types.User, error) {
|
|
user := types.User{
|
|
ID: uuid.New().String(),
|
|
SessionID: uuid.New().String(),
|
|
Username: strings.ToLower(body.Username),
|
|
Name: body.Name,
|
|
FiscalCode: body.FiscalCode,
|
|
Address: body.Address,
|
|
Zip: body.Zip,
|
|
Country: body.Country,
|
|
Phone: body.Phone,
|
|
Email: body.Email,
|
|
IssuedInvoicesThisYear: 0,
|
|
}
|
|
|
|
result := db.instance.Create(&user)
|
|
|
|
if result.Error != nil {
|
|
return types.User{}, result.Error
|
|
}
|
|
|
|
return user, nil
|
|
}
|
|
|
|
func (db *DB) GetUsers() ([]types.User, error) {
|
|
var users []types.User
|
|
|
|
result := db.instance.Model(&types.User{}).Preload("Clients").Find(&users)
|
|
|
|
if result.Error != nil {
|
|
return nil, result.Error
|
|
}
|
|
|
|
return users, nil
|
|
}
|
|
|
|
func (db *DB) GetUserById(id uuid.UUID, user *types.User) error {
|
|
result := db.instance.Model(&types.User{}).Preload("Clients").Where("id = ?", id).First(user)
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) GetUserBySessionId(sessionId uuid.UUID, user *types.User) error {
|
|
result := db.instance.Where("session_id = ?", sessionId).First(user)
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) GetUserByUsername(username string, user *types.User) error {
|
|
result := db.instance.Where("username = ?", username).First(user)
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) UpdateUser(id uuid.UUID, body types.UpdateUserRequestBody, user *types.User) error {
|
|
result := db.instance.Where("id = ?", id).First(user, id)
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
result = db.instance.Model(user).Updates(types.User{
|
|
Username: strings.ToLower(body.Username),
|
|
Name: body.Name,
|
|
FiscalCode: body.FiscalCode,
|
|
Address: body.Address,
|
|
Zip: body.Zip,
|
|
Country: body.Country,
|
|
Phone: body.Phone,
|
|
Email: body.Email,
|
|
})
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) UpdateUserIssuesInvoicesThisYear(id uuid.UUID, issuedInvoicesThisYear uint32, user *types.User) error {
|
|
result := db.instance.Where("id = ?", id).First(user, id)
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
result = db.instance.Model(user).Updates(types.User{
|
|
IssuedInvoicesThisYear: issuedInvoicesThisYear,
|
|
})
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) UpdateUserSecurityCredentials(id uuid.UUID, body types.UpdateUserSecurityCredentialsBody, user *types.User) error {
|
|
result := db.instance.Where("id = ?", id).First(user, id)
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
hashedPassword, err := lib.HashPassword(body.Password)
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
result = db.instance.Model(user).Updates(types.User{
|
|
Password: hashedPassword,
|
|
})
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) UpdateUserLogo(path string, user *types.User) error {
|
|
result := db.instance.Model(user).Updates(types.User{
|
|
Logo: path,
|
|
})
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) UpdateUserSessionID(user *types.User) error {
|
|
result := db.instance.Model(user).Updates(types.User{
|
|
SessionID: uuid.New().String(),
|
|
})
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) DeleteUser(id uuid.UUID) error {
|
|
result := db.instance.Unscoped().Delete(&types.User{}, id)
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) DeleteUserLogo(user *types.User) error {
|
|
result := db.instance.Model(user).Updates(&types.User{
|
|
Logo: "",
|
|
})
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (db *DB) DeleteUserSessionID(sessionId string) error {
|
|
result := db.instance.Model(&types.User{}).Where("session_id = ?", sessionId).Update("session_id", "")
|
|
|
|
if result.Error != nil {
|
|
return result.Error
|
|
}
|
|
|
|
return nil
|
|
}
|