mirror of
https://codeberg.org/shroff/phylum.git
synced 2026-01-23 04:34:47 -06:00
55 lines
1.5 KiB
Go
55 lines
1.5 KiB
Go
package user
|
|
|
|
import (
|
|
"github.com/jackc/pgx/v5/pgtype"
|
|
"github.com/shroff/phylum/server/internal/crypt"
|
|
)
|
|
|
|
func (m manager) UpdateUserHome(user User, home pgtype.UUID) error {
|
|
const q = "UPDATE users SET home = $2::UUID, modified = NOW() WHERE id = $1::INT"
|
|
if _, err := m.db.Exec(q, user.ID, home); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) UpdateUserName(user User, name string) error {
|
|
const q = "UPDATE users SET name = $2::TEXT, modified = NOW() WHERE id = $1::INT"
|
|
if _, err := m.db.Exec(q, user.ID, name); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) UpdateUserPassword(user User, password string) error {
|
|
if err := checkPasswordStrength(password); err != nil {
|
|
return err
|
|
}
|
|
|
|
const q = "UPDATE users SET password_hash = $2::TEXT, modified = NOW() WHERE id = $1::INT"
|
|
if hash, err := crypt.Generate(password); err != nil {
|
|
return err
|
|
} else {
|
|
if _, err := m.db.Exec(q, user.ID, hash); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) GrantUserPermissions(user User, permissions Permissions) error {
|
|
const q = "UPDATE users SET permissions = permissions | $2::INTEGER, modified = NOW() WHERE id = $1::INT"
|
|
if _, err := m.db.Exec(q, user.ID, permissions); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) RevokeUserPermissions(user User, permissions Permissions) error {
|
|
const q = "UPDATE users SET permissions = permissions & ~ $2::INTEGER, modified = NOW() WHERE id = $1::INT"
|
|
if _, err := m.db.Exec(q, user.ID, permissions); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|