feat: add user role update routes
This commit is contained in:
parent
ded376d971
commit
34ca61809b
|
|
@ -189,3 +189,27 @@
|
||||||
"deactivated"
|
"deactivated"
|
||||||
"activated")
|
"activated")
|
||||||
(dm:field user "username"))))))))))
|
(dm:field user "username"))))))))))
|
||||||
|
|
||||||
|
(define-api asteroid/user/role (user-id role) ()
|
||||||
|
"API endpoint for setting the access role of an user account"
|
||||||
|
(format t "Role of user: #~a set to ~a~%" user-id role)
|
||||||
|
(require-role :admin)
|
||||||
|
(with-error-handling
|
||||||
|
(let ((user (when user-id
|
||||||
|
(find-user-by-id user-id)))
|
||||||
|
(user-role (intern (string-upcase role) :keyword)))
|
||||||
|
|
||||||
|
(unless user
|
||||||
|
(error 'not-found-error :message "User not found"))
|
||||||
|
|
||||||
|
;; Change user role
|
||||||
|
(let ((result (update-user-role user-id user-role)))
|
||||||
|
(if result
|
||||||
|
(api-output `(("status" . "success")
|
||||||
|
("message" . ,(format nil "User '~a' is now a ~a."
|
||||||
|
(dm:field user "username")
|
||||||
|
role))))
|
||||||
|
(api-output `(("status" . "error")
|
||||||
|
("message" . ,(format nil "Could not set user '~a' as ~a."
|
||||||
|
(dm:field user "username")
|
||||||
|
role)))))))))
|
||||||
|
|
|
||||||
|
|
@ -90,20 +90,23 @@ function hideUsersTable() {
|
||||||
async function updateUserRole(userId, newRole) {
|
async function updateUserRole(userId, newRole) {
|
||||||
try {
|
try {
|
||||||
const formData = new FormData();
|
const formData = new FormData();
|
||||||
|
formData.append('user-id', userId);
|
||||||
formData.append('role', newRole);
|
formData.append('role', newRole);
|
||||||
|
|
||||||
const response = await fetch(`/api/asteroid/users/${userId}/role`, {
|
const response = await fetch('/api/asteroid/user/role', {
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
body: formData
|
body: formData
|
||||||
});
|
});
|
||||||
|
|
||||||
const result = await response.json();
|
const result = await response.json();
|
||||||
|
// Handle Radiance API data wrapping
|
||||||
|
const data = result.data || result;
|
||||||
|
|
||||||
if (result.status === 'success') {
|
if (data.status === 'success') {
|
||||||
loadUserStats();
|
loadUserStats();
|
||||||
alert('User role updated successfully');
|
alert(data.message);
|
||||||
} else {
|
} else {
|
||||||
alert('Error updating user role: ' + result.message);
|
alert('Error updating user role: ' + data.message);
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error('Error updating user role:', error);
|
console.error('Error updating user role:', error);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue