import type { Handle, HandleServerError } from '@sveltejs/kit'; import { AxiosError } from 'axios'; import { env } from '$env/dynamic/public'; import { ImmichApi } from './api/api'; export const handle = (async ({ event, resolve }) => { const basePath = env.PUBLIC_IMMICH_SERVER_URL || 'http://immich-server:3001'; const accessToken = event.cookies.get('immich_access_token'); const api = new ImmichApi({ basePath, accessToken }); // API instance that should be used for all server-side requests. event.locals.api = api; if (accessToken) { try { const { data: user } = await api.userApi.getMyUserInfo(); event.locals.user = user; } catch (err) { const apiError = err as AxiosError; // Ignore 401 unauthorized errors and log all others. if (apiError.response?.status !== 401) { console.error('[ERROR] hooks.server.ts [handle]:', err); } } } const res = await resolve(event); // The link header can grow quite big and has caused issues with our nginx // proxy returning a 502 Bad Gateway error. Therefore the header gets deleted. res.headers.delete('Link'); return res; }) satisfies Handle; export const handleError: HandleServerError = async ({ error }) => { const httpError = error as AxiosError; return { message: httpError?.message || 'Hmm, not sure about that. Check the logs or open a ticket?', stack: httpError?.stack, code: httpError.code || '500' }; };