mirror of
https://codeberg.org/shroff/phylum.git
synced 2026-01-20 19:19:51 -06:00
54 lines
1.6 KiB
Go
54 lines
1.6 KiB
Go
package user
|
|
|
|
import (
|
|
"github.com/google/uuid"
|
|
)
|
|
|
|
func (m manager) UpdateUserRoot(user User, root uuid.UUID) error {
|
|
const q = "UPDATE users SET root = $2::UUID, modified = NOW() WHERE username = $1::TEXT"
|
|
if _, err := m.db.Exec(q, user.Username, root); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) UpdateUserHome(user User, home uuid.UUID) error {
|
|
const q = "UPDATE users SET home = $2::UUID, modified = NOW() WHERE username = $1::TEXT"
|
|
if _, err := m.db.Exec(q, user.Username, home); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) UpdateUserDisplayName(user User, displayName string) error {
|
|
const q = "UPDATE users SET display_name = $2::UUID, modified = NOW() WHERE username = $1::TEXT"
|
|
if _, err := m.db.Exec(q, user.Username, displayName); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) UpdateUserPasswordHash(user User, passwordHash string) error {
|
|
const q = "UPDATE users SET password_hash = $2::TEXT, modified = NOW() WHERE username = $1::TEXT"
|
|
if _, err := m.db.Exec(q, user.Username, passwordHash); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) GrantUserPermissions(user User, permissions int) error {
|
|
const q = "UPDATE users SET permissions = permissions | $2::INTEGER, modified = NOW() WHERE username = $1::UUID"
|
|
if _, err := m.db.Exec(q, user.Username, permissions); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m manager) RevokeUserPermissions(user User, permissions int) error {
|
|
const q = "UPDATE users SET permissions = permissions & ~ $2::INTEGER, modified = NOW() WHERE username = $1::UUID"
|
|
if _, err := m.db.Exec(q, user.Username, permissions); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|