2023-01-13 23:04:59 +01:00
|
|
|
import type { Handle, HandleServerError } from '@sveltejs/kit';
|
|
|
|
import { AxiosError } from 'axios';
|
2023-02-24 21:42:20 +01:00
|
|
|
import { env } from '$env/dynamic/public';
|
|
|
|
import { ImmichApi } from './api/api';
|
|
|
|
|
|
|
|
export const handle = (async ({ event, resolve }) => {
|
2023-02-26 17:50:18 +01:00
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-05-21 09:23:55 +02:00
|
|
|
|
2023-02-15 13:40:52 +01:00
|
|
|
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;
|
2023-02-24 21:42:20 +01:00
|
|
|
}) satisfies Handle;
|
2023-01-13 23:04:59 +01:00
|
|
|
|
|
|
|
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'
|
|
|
|
};
|
|
|
|
};
|