aboutsummaryrefslogtreecommitdiff
path: root/src/routes/api/oauth
diff options
context:
space:
mode:
authorFuwn <[email protected]>2023-09-13 01:54:06 -0700
committerFuwn <[email protected]>2023-09-13 01:54:06 -0700
commit134c88f914dfde9a85183a2370f2322a9509d08c (patch)
tree1f4f82a226f6e19379b7862da057dc596f5b6b03 /src/routes/api/oauth
parentrefactor(auth): move to api (diff)
downloaddue.moe-134c88f914dfde9a85183a2370f2322a9509d08c.tar.xz
due.moe-134c88f914dfde9a85183a2370f2322a9509d08c.zip
refactor(oauth): move to api
Diffstat (limited to 'src/routes/api/oauth')
-rw-r--r--src/routes/api/oauth/callback/+server.ts34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/routes/api/oauth/callback/+server.ts b/src/routes/api/oauth/callback/+server.ts
new file mode 100644
index 00000000..33ba6de9
--- /dev/null
+++ b/src/routes/api/oauth/callback/+server.ts
@@ -0,0 +1,34 @@
+import { dev } from '$app/environment';
+import { env } from '$env/dynamic/private';
+import { env as env2 } from '$env/dynamic/public';
+import { redirect } from '@sveltejs/kit';
+
+export const GET = async ({ url, cookies }) => {
+ const formData = new FormData();
+
+ formData.append('grant_type', 'authorization_code');
+ formData.append('client_id', env2.PUBLIC_ANILIST_CLIENT_ID);
+ formData.append('client_secret', env.ANILIST_CLIENT_SECRET);
+ formData.append('redirect_uri', env2.PUBLIC_ANILIST_REDIRECT_URI);
+ formData.append('code', url.searchParams.get('code') || 'null');
+ cookies.set(
+ 'user',
+ JSON.stringify(
+ await (
+ await fetch('https://anilist.co/api/v2/oauth/token', {
+ method: 'POST',
+ body: formData
+ })
+ ).json()
+ ),
+ {
+ path: '/',
+ maxAge: 60 * 60 * 24 * 7,
+ httpOnly: true,
+ sameSite: 'lax',
+ secure: !dev
+ }
+ );
+
+ throw redirect(303, '/');
+};