feat: API for getting single api service
This commit is contained in:
@ -44,3 +44,14 @@ export const postApiService = async (
|
|||||||
|
|
||||||
return response.data;
|
return response.data;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const getApiService = async (id: string): Promise<ApiService> => {
|
||||||
|
const response = await axios.get<ApiService>(
|
||||||
|
`/api/v1/admin/api-services/${id}`,
|
||||||
|
);
|
||||||
|
|
||||||
|
if (response.status !== 200 && response.status !== 201)
|
||||||
|
throw await handleApiError(response);
|
||||||
|
|
||||||
|
return response.data;
|
||||||
|
};
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import {
|
import {
|
||||||
|
getApiService,
|
||||||
getApiServices,
|
getApiServices,
|
||||||
postApiService,
|
postApiService,
|
||||||
type CreateApiServiceRequest,
|
type CreateApiServiceRequest,
|
||||||
@ -13,7 +14,11 @@ interface IAdminState {
|
|||||||
createdCredentials: ApiServiceCredentials | null;
|
createdCredentials: ApiServiceCredentials | null;
|
||||||
creatingApiService: boolean;
|
creatingApiService: boolean;
|
||||||
|
|
||||||
|
viewApiService: ApiService | null;
|
||||||
|
fetchingApiService: boolean;
|
||||||
|
|
||||||
fetchApiServices: () => Promise<void>;
|
fetchApiServices: () => Promise<void>;
|
||||||
|
fetchApiService: (id: string) => Promise<void>;
|
||||||
createApiService: (req: CreateApiServiceRequest) => Promise<void>;
|
createApiService: (req: CreateApiServiceRequest) => Promise<void>;
|
||||||
resetCredentials: () => void;
|
resetCredentials: () => void;
|
||||||
}
|
}
|
||||||
@ -25,6 +30,9 @@ export const useAdmin = create<IAdminState>((set) => ({
|
|||||||
createdCredentials: null,
|
createdCredentials: null,
|
||||||
creatingApiService: false,
|
creatingApiService: false,
|
||||||
|
|
||||||
|
viewApiService: null,
|
||||||
|
fetchingApiService: false,
|
||||||
|
|
||||||
resetCredentials: () => set({ createdCredentials: null }),
|
resetCredentials: () => set({ createdCredentials: null }),
|
||||||
|
|
||||||
fetchApiServices: async () => {
|
fetchApiServices: async () => {
|
||||||
@ -40,6 +48,19 @@ export const useAdmin = create<IAdminState>((set) => ({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
fetchApiService: async (id: string) => {
|
||||||
|
set({ fetchingApiService: true });
|
||||||
|
|
||||||
|
try {
|
||||||
|
const response = await getApiService(id);
|
||||||
|
set({ viewApiService: response });
|
||||||
|
} catch (err) {
|
||||||
|
console.log("ERR: Failed to fetch services:", err);
|
||||||
|
} finally {
|
||||||
|
set({ fetchingApiService: false });
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
createApiService: async (req: CreateApiServiceRequest) => {
|
createApiService: async (req: CreateApiServiceRequest) => {
|
||||||
set({ creatingApiService: true });
|
set({ creatingApiService: true });
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user