Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 | import { LambdaApiFunction, handleResourceApi } from './_base'; import { getCookies, getDeleteCookieHeader } from './_utils'; import { api302Body, generateApi400Body } from '@/types/api/_shared'; import { LogoutApi, logoutApiQueryValidator } from '@/types/api/auth'; import { validateObject } from '@/utils/backend/validation'; import { getLogger } from '@/utils/common/logger'; const logger = getLogger('stack/resources/api/v2/logout'); const GET: LambdaApiFunction<LogoutApi> = async function (event) { logger.trace('GET', ...arguments); // Validate the query parameters const [ query, queryErrors, ] = validateObject<LogoutApi['query']>( event.queryStringParameters || {}, logoutApiQueryValidator ); if ( query === null || queryErrors.length > 0 ) { return [ 400, generateApi400Body(queryErrors), ]; } // Default to returning to the homepage if (typeof query.redirectTo === 'undefined') { query.redirectTo = '/'; } // Find the cookies to delete const cookies = getCookies(event); const setCookieHeaders: string[] = []; Object.keys(cookies) .filter(key => key.includes('cvfd') || key.includes('cofrn')) .forEach(key => setCookieHeaders.push(getDeleteCookieHeader(key))); // Return the response return [ 302, api302Body, { 'Set-Cookie': setCookieHeaders, 'Location': [ query.redirectTo, ], }, ]; }; export const main = handleResourceApi.bind(null, { GET, }); |