import {api_base, CookieNames} from "$configuration"; import {log_debug, log_error} from "$help/logger"; import {error, redirect} from "@sveltejs/kit"; import {Temporal} from "temporal-polyfill"; import type {LayoutServerLoad} from "./$types"; export const load: LayoutServerLoad = async ({url, request, route, cookies, locals, fetch}) => { console.log(url.toString()); const isBaseRoute = route.id === "/(main)"; const isPublicRoute = (route.id?.startsWith("/(main)/(public)") || isBaseRoute) ?? true; const sessionCookieValue = cookies.get(CookieNames.session); const hasSessionCookie = (sessionCookieValue?.length > 0 ?? false); const sessionIsValid = hasSessionCookie && (await cached_result_async("sessionCheck", 120, () => fetch(api_base("_/is-authenticated"), { headers: { Cookie: CookieNames.session + "=" + sessionCookieValue, }, }).catch((e) => { log_error(e); throw error(503, { message: "We are experiencing a service disruption! Have patience while we resolve the issue.", }); }))).ok; log_debug("Base Layout loaded", { sessionIsValid, isPublicRoute, routeId: route.id, }); if (sessionIsValid && isPublicRoute) { throw redirect(302, "/home"); } else if (isBaseRoute || !sessionIsValid && !isPublicRoute) { throw redirect(302, "/sign-in"); } return { locale: locals.locale, }; }; let resultCache = {}; async function cached_result_async(key: string, staleAfterSeconds: number, get_result: any, forceRefresh: boolean = false) { if (!resultCache[key]) { resultCache[key] = { l: 0, c: undefined as T, }; } const staleEpoch = ((resultCache[key]?.l ?? 0) + staleAfterSeconds); const isStale = forceRefresh || (staleEpoch < Temporal.Now.instant().epochSeconds); if (isStale || !resultCache[key]?.c) { resultCache[key].c = await get_result(); resultCache[key].l = Temporal.Now.instant().epochSeconds; } log_debug("Ran cached_result_async", { cacheKey: key, isStale, cache: resultCache[key], staleEpoch, }); return resultCache[key].c as T; }