|
import { redirect, error } from "@sveltejs/kit"; |
|
import { getOIDCUserData, validateAndParseCsrfToken } from "$lib/server/auth"; |
|
import { z } from "zod"; |
|
import { base } from "$app/paths"; |
|
import { updateUser } from "./updateUser"; |
|
|
|
export async function load({ url, locals, cookies }) { |
|
const { error: errorName, error_description: errorDescription } = z |
|
.object({ |
|
error: z.string().optional(), |
|
error_description: z.string().optional(), |
|
}) |
|
.parse(Object.fromEntries(url.searchParams.entries())); |
|
|
|
if (errorName) { |
|
throw error(400, errorName + (errorDescription ? ": " + errorDescription : "")); |
|
} |
|
|
|
const { code, state } = z |
|
.object({ |
|
code: z.string(), |
|
state: z.string(), |
|
}) |
|
.parse(Object.fromEntries(url.searchParams.entries())); |
|
|
|
const csrfToken = Buffer.from(state, "base64").toString("utf-8"); |
|
|
|
const validatedToken = await validateAndParseCsrfToken(csrfToken, locals.sessionId); |
|
|
|
if (!validatedToken) { |
|
throw error(403, "Invalid or expired CSRF token"); |
|
} |
|
|
|
const { userData } = await getOIDCUserData({ redirectURI: validatedToken.redirectUrl }, code); |
|
|
|
await updateUser({ userData, locals, cookies }); |
|
|
|
throw redirect(302, `${base}/`); |
|
} |
|
|