aboutsummaryrefslogtreecommitdiff
path: root/src/routes/loggedin/+server.ts
diff options
context:
space:
mode:
authormat <27899617+mat-1@users.noreply.github.com>2022-12-15 20:19:42 -0600
committerGitHub <noreply@github.com>2022-12-15 20:19:42 -0600
commited5eedab8f9fc90dadf5c442cf559572d1b35f0c (patch)
tree01a763fd11810e9970f14f7dae180e95b279de9a /src/routes/loggedin/+server.ts
parent89bf3d31e36ad3bdfd45461ee6fb69a4c791f848 (diff)
parent103689520f51991a1e9a4ca5829fe2f46d1a32c2 (diff)
downloadskyblock-stats-ed5eedab8f9fc90dadf5c442cf559572d1b35f0c.tar.gz
skyblock-stats-ed5eedab8f9fc90dadf5c442cf559572d1b35f0c.tar.bz2
skyblock-stats-ed5eedab8f9fc90dadf5c442cf559572d1b35f0c.zip
Merge pull request #6 from skyblockstats/sveltekit-v1
Sveltekit v1
Diffstat (limited to 'src/routes/loggedin/+server.ts')
-rw-r--r--src/routes/loggedin/+server.ts30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/routes/loggedin/+server.ts b/src/routes/loggedin/+server.ts
new file mode 100644
index 0000000..4772cf6
--- /dev/null
+++ b/src/routes/loggedin/+server.ts
@@ -0,0 +1,30 @@
+import { fetchApi } from '$lib/api'
+import { redirect, type RequestHandler, } from '@sveltejs/kit'
+
+export const GET = (async ({ url, cookies }) => {
+ const code = url.searchParams.get('code')
+ const redirectUri = `${url.protocol}//${url.host}/loggedin`
+ const response = await fetchApi(`accounts/createsession`, fetch, {
+ method: 'POST',
+ headers: {
+ 'content-type': 'application/json',
+ },
+ body: JSON.stringify({
+ code,
+ redirectUri: redirectUri
+ }),
+ }).then(res => {
+ if (res.status !== 200)
+ throw new Error(res.statusText)
+ return res.json()
+ })
+
+ if (response.ok) {
+ cookies.set('sid', response.session_id, {
+ maxAge: 31536000000,
+ httpOnly: true,
+ })
+ throw redirect(303, '/verify')
+ }
+ throw redirect(303, '/login')
+}) satisfies RequestHandler