From d7f4f11ced83477f42a98cf99f8460f0bb2a7148 Mon Sep 17 00:00:00 2001 From: Imbus Date: Thu, 14 Dec 2023 16:47:34 +0100 Subject: [PATCH] API boilerplate gluecode --- src/util/api.ts | 76 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100644 src/util/api.ts diff --git a/src/util/api.ts b/src/util/api.ts new file mode 100644 index 0000000..43536d3 --- /dev/null +++ b/src/util/api.ts @@ -0,0 +1,76 @@ +// This file contains types and functions related to interacting with the API. +const URL = "https://shitpost.se"; + +export interface NewPost { + content: string; + token: string; +} + +interface Votes { + up: number; + down: number; +} + +export interface Post extends NewPost { + id: string; + createdAt: string; + votes: Votes; +} + +// This is what the login and registration responses look like +export interface AuthResponse { + username: string; + token: string; +} + +export async function getPosts(): Promise { + const res = await fetch("/api/posts"); + const data = await res.json(); + return data; +} + +export async function getPost(id: string): Promise { + const res = await fetch(`/api/posts/${id}`); + const data = await res.json(); + return data; +} + +export async function createPost(post: NewPost): Promise { + await fetch("/api/posts", { + method: "POST", + headers: { + "Content-Type": "application/json", + }, + body: JSON.stringify(post), + }); +} + +// Send the registration request to the server +export async function submitRegistration( + username: string, + password: string, + captcha: string +): Promise { + const response = await fetch("/api/register", { + method: "POST", + headers: { "Content-Type": "application/json" }, + body: JSON.stringify({ username, password, captcha }), + }); + + if (response.ok) return await response.json(); +} + +// Send the login request to the server +export async function submitLogin( + username: string, + password: string +): Promise { + if (username == "" || password == "") return; + const response = await fetch("/api/login", { + method: "POST", + headers: { "Content-Type": "application/json" }, + body: JSON.stringify({ username, password }), + }); + + if (response.ok) return await response.json(); +}