Basic api funcitonality in frontend

This commit is contained in:
Imbus 2024-03-13 17:06:26 +01:00
parent 6b09cfbf23
commit 3a7663124d
2 changed files with 43 additions and 0 deletions

32
frontend/src/API/API.ts Normal file
View file

@ -0,0 +1,32 @@
import { NewUser, User } from "../Types/Users";
// Defines all the methods that an instance of the API must implement
interface API {
/** Register a new user */
registerUser(user: NewUser): Promise<User>;
/** Remove a user */
removeUser(username: string): Promise<User>;
}
// Export an instance of the API
export const api: API = {
async registerUser(user: NewUser): Promise<User> {
return fetch("/api/register", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(user),
}).then((res) => res.json() as Promise<User>);
},
async removeUser(username: string): Promise<User> {
return fetch("/api/userdelete", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(username),
}).then((res) => res.json() as Promise<User>);
},
};

View file

@ -0,0 +1,11 @@
// This is how the API responds
export interface User {
id: number;
name: string;
}
// Used to create a new user
export interface NewUser {
name: string;
password: string;
}