mirror of
https://github.com/lordmathis/lemma.git
synced 2025-11-06 16:04:23 +00:00
Migrate admin API to typescript
This commit is contained in:
157
app/src/api/admin.ts
Normal file
157
app/src/api/admin.ts
Normal file
@@ -0,0 +1,157 @@
|
||||
import { apiCall } from './api';
|
||||
import { API_BASE_URL, isUser, User } from '../types/authApi';
|
||||
import {
|
||||
CreateUserRequest,
|
||||
isSystemStats,
|
||||
SystemStats,
|
||||
UpdateUserRequest,
|
||||
} from '@/types/adminApi';
|
||||
import { isWorkspace, Workspace } from '@/types/workspace';
|
||||
|
||||
const ADMIN_BASE_URL = `${API_BASE_URL}/admin`;
|
||||
|
||||
// User Management
|
||||
|
||||
/**
|
||||
* Fetches all users from the API
|
||||
* @returns {Promise<User[]>} A promise that resolves to an array of users
|
||||
* @throws {Error} If the API call fails or returns an invalid response
|
||||
* */
|
||||
export const getUsers = async (): Promise<User[]> => {
|
||||
const response = await apiCall(`${ADMIN_BASE_URL}/users`);
|
||||
|
||||
if (!response.ok) {
|
||||
const data = await response.json();
|
||||
const errorData = data as { message: string };
|
||||
throw new Error(errorData.message || 'Failed to fetch users');
|
||||
}
|
||||
|
||||
const data = await response.json();
|
||||
if (!Array.isArray(data)) {
|
||||
throw new Error('Invalid users response received from API');
|
||||
}
|
||||
return data.map((user) => {
|
||||
if (!isUser(user)) {
|
||||
throw new Error('Invalid user object received from API');
|
||||
}
|
||||
return user as User;
|
||||
});
|
||||
};
|
||||
|
||||
/**
|
||||
* Creates a new user in the system
|
||||
* @param {CreateUserRequest} userData The data for the new user
|
||||
* @returns {Promise<User>} A promise that resolves to the created user
|
||||
* @throws {Error} If the API call fails or returns an invalid response
|
||||
* */
|
||||
export const createUser = async (
|
||||
userData: CreateUserRequest
|
||||
): Promise<User> => {
|
||||
const response = await apiCall(`${ADMIN_BASE_URL}/users`, {
|
||||
method: 'POST',
|
||||
body: JSON.stringify(userData),
|
||||
});
|
||||
|
||||
if (!response.ok) {
|
||||
const data = await response.json();
|
||||
const errorData = data as { message: string };
|
||||
throw new Error(errorData.message || 'Failed to create user');
|
||||
}
|
||||
|
||||
const data = await response.json();
|
||||
if (!isUser(data)) {
|
||||
throw new Error('Invalid user object received from API');
|
||||
}
|
||||
return data as User;
|
||||
};
|
||||
|
||||
/**
|
||||
* Deletes a user from the system
|
||||
* @param {number} userId The ID of the user to delete
|
||||
* @throws {Error} If the API call fails or returns an invalid response
|
||||
* */
|
||||
export const deleteUser = async (userId: number) => {
|
||||
const response = await apiCall(`${ADMIN_BASE_URL}/users/${userId}`, {
|
||||
method: 'DELETE',
|
||||
});
|
||||
if (response.status === 204) {
|
||||
return;
|
||||
} else {
|
||||
throw new Error('Failed to delete user with status: ' + response.status);
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* Updates an existing user in the system
|
||||
* @param {number} userId The ID of the user to update
|
||||
* @param {UpdateUserRequest} userData The data to update the user with
|
||||
* @returns {Promise<User>} A promise that resolves to the updated user
|
||||
* @throws {Error} If the API call fails or returns an invalid response
|
||||
* */
|
||||
export const updateUser = async (
|
||||
userId: number,
|
||||
userData: UpdateUserRequest
|
||||
): Promise<User> => {
|
||||
const response = await apiCall(`${ADMIN_BASE_URL}/users/${userId}`, {
|
||||
method: 'PUT',
|
||||
body: JSON.stringify(userData),
|
||||
});
|
||||
|
||||
if (!response.ok) {
|
||||
const data = await response.json();
|
||||
const errorData = data as { message: string };
|
||||
throw new Error(errorData.message || 'Failed to update user');
|
||||
}
|
||||
const data = await response.json();
|
||||
if (!isUser(data)) {
|
||||
throw new Error('Invalid user object received from API');
|
||||
}
|
||||
return data as User;
|
||||
};
|
||||
|
||||
// Workspace Management
|
||||
|
||||
/**
|
||||
* Fetches all workspaces from the API
|
||||
* @returns {Promise<Workspace[]>} A promise that resolves to an array of workspaces
|
||||
* @throws {Error} If the API call fails or returns an invalid response
|
||||
* */
|
||||
export const getWorkspaces = async (): Promise<Workspace[]> => {
|
||||
const response = await apiCall(`${ADMIN_BASE_URL}/workspaces`);
|
||||
if (!response.ok) {
|
||||
const data = await response.json();
|
||||
const errorData = data as { message: string };
|
||||
throw new Error(errorData.message || 'Failed to fetch workspaces');
|
||||
}
|
||||
const data = await response.json();
|
||||
if (!Array.isArray(data)) {
|
||||
throw new Error('Invalid workspaces response received from API');
|
||||
}
|
||||
return data.map((workspace) => {
|
||||
if (!isWorkspace(workspace)) {
|
||||
throw new Error('Invalid workspace object received from API');
|
||||
}
|
||||
return workspace as Workspace;
|
||||
});
|
||||
};
|
||||
|
||||
// System Statistics
|
||||
|
||||
/**
|
||||
* Fetches system-wide statistics from the API
|
||||
* @returns {Promise<SystemStats>} A promise that resolves to the system statistics
|
||||
* @throws {Error} If the API call fails or returns an invalid response
|
||||
* */
|
||||
export const getSystemStats = async (): Promise<SystemStats> => {
|
||||
const response = await apiCall(`${ADMIN_BASE_URL}/stats`);
|
||||
if (!response.ok) {
|
||||
const data = await response.json();
|
||||
const errorData = data as { message: string };
|
||||
throw new Error(errorData.message || 'Failed to fetch system stats');
|
||||
}
|
||||
const data = await response.json();
|
||||
if (!isSystemStats(data)) {
|
||||
throw new Error('Invalid system stats response received from API');
|
||||
}
|
||||
return data as SystemStats;
|
||||
};
|
||||
Reference in New Issue
Block a user