aboutsummaryrefslogtreecommitdiffstats
path: root/src/routes/login/undo/+server.ts
blob: a3559d6500fecd41c328ea306508aa0ebd110683 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
import * as auth from '$lib/auth.server.js';
import { error, redirect } from '@sveltejs/kit';
import * as client from 'openid-client';
export const GET = async (event) => {
  const token = event.cookies.get('oid__access_token');
  if (!token) throw error(403, 'Logout requires an access token!');
  await client.tokenRevocation(await auth.getConfig(), token);
  let target =
    event.url.searchParams.get('next') ?? event.cookies.get('next') ?? '/';
  if (new URL(target, event.url.href).host !== event.url.host) target = '/';
  event.cookies.delete('next', {
    path: '/',
  });
  auth.unsetCookies(event.cookies);
  throw redirect(303, `/login/callback/ok?next=${encodeURIComponent(target)}`);
};