| import { redirect } from "@sveltejs/kit"; | |
| import { getOIDCAuthorizationUrl } from "$lib/server/auth"; | |
| import { base } from "$app/paths"; | |
| import { ALTERNATIVE_REDIRECT_URLS } from "$env/static/private"; | |
| export const actions = { | |
| async default({ url, locals, request }) { | |
| const referer = request.headers.get("referer"); | |
| let redirectURI = `${(referer ? new URL(referer) : url).origin}${base}/login/callback`; | |
| // TODO: Handle errors if provider is not responding | |
| if (url.searchParams.has("callback")) { | |
| const callback = url.searchParams.get("callback") || redirectURI; | |
| if (ALTERNATIVE_REDIRECT_URLS.includes(callback)) { | |
| redirectURI = callback; | |
| } | |
| } | |
| const authorizationUrl = await getOIDCAuthorizationUrl( | |
| { redirectURI }, | |
| { sessionId: locals.sessionId } | |
| ); | |
| throw redirect(303, authorizationUrl); | |
| }, | |
| }; | |