package user import ( "github.com/jackc/pgx/v5/pgtype" "github.com/shroff/phylum/server/internal/core/util/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) UpdateUserDisplayName(user User, displayName string) error { const q = "UPDATE users SET display_name = $2::TEXT, modified = NOW() WHERE id = $1::INT" if _, err := m.db.Exec(q, user.ID, displayName); err != nil { return err } return nil } func (m manager) UpdateUserPassword(user User, password string) error { const q = "UPDATE users SET password_hash = $2::TEXT, modified = NOW() WHERE id = $1::INT" if hash, err := crypt.GenerateArgon2EncodedHash(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 int) 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 int) 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 }