aboutsummaryrefslogtreecommitdiff
path: root/src/routes/api/preferences/+server.ts
blob: 47ce442b61d78c9d755fd96c2ad33dcd569d1afb (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
import { Schema } from "effect";
import { safeUserIdentity } from "$lib/Data/AniList/identity";
import {
	getUserPreferences,
	setBiography,
	setCSS,
	setPinnedBadgeWallCategories,
	toggleHideAWCBadges,
	toggleHideMissingBadges,
	togglePinnedBadgeWallCategory,
} from "$lib/Database/SB/User/preferences";
import { decodeAuthCookieOrNull } from "$lib/Effect/authCookie";
import { decodeRequestJsonOrThrow } from "$lib/Effect/requestBody";
import { appOriginHeaders } from "$lib/Utility/appOrigin";

const unauthorised = new Response("Unauthorised", { status: 401 });

const authenticatedUserId = async (cookies: {
	get: (name: string) => string | undefined;
}) => {
	const userCookie = cookies.get("user");

	if (!userCookie) return null;

	const user = decodeAuthCookieOrNull(userCookie);

	if (!user) return null;

	return (await safeUserIdentity(user))?.id ?? null;
};

export const GET = async ({ url }) => {
	const requestedUserId = Number(url.searchParams.get("id") || 0);

	const preferences = await getUserPreferences(requestedUserId);

	return Response.json(preferences ? preferences : {}, {
		headers: appOriginHeaders(),
	});
};

export const PUT = async ({ url, cookies, request }) => {
	const userId = await authenticatedUserId(cookies);

	if (!userId) return unauthorised;

	if (url.searchParams.get("toggleHideMissingBadges") !== null)
		return Response.json(await toggleHideMissingBadges(userId), {
			headers: appOriginHeaders(),
		});

	if (url.searchParams.get("toggleHideAWCBadges") !== null)
		return Response.json(await toggleHideAWCBadges(userId), {
			headers: appOriginHeaders(),
		});

	if (url.searchParams.get("badgeWallCSS") !== null)
		return Response.json(await setCSS(userId, await request.text()), {
			headers: appOriginHeaders(),
		});

	if (url.searchParams.get("toggleCategory") !== null)
		return Response.json(
			await togglePinnedBadgeWallCategory(
				userId,
				url.searchParams.get("toggleCategory") || "",
			),
			{
				headers: appOriginHeaders(),
			},
		);

	if (url.searchParams.get("setCategories") !== null)
		return Response.json(
			await setPinnedBadgeWallCategories(userId, [
				...(await decodeRequestJsonOrThrow(
					request,
					Schema.Array(Schema.String),
				)),
			]),
			{
				headers: appOriginHeaders(),
			},
		);

	if (url.searchParams.get("biography") !== null)
		return Response.json(
			await setBiography(userId, (await request.text()).slice(0, 3000)),
			{
				headers: appOriginHeaders(),
			},
		);

	return Response.json(
		await getUserPreferences(Number(url.searchParams.get("id") || 0)),
		{
			headers: appOriginHeaders(),
		},
	);
};