feat: better issues handling
This commit is contained in:
parent
5c00cd447d
commit
625bcc3882
3 changed files with 24 additions and 15 deletions
12
src/hooks.client.ts
Normal file
12
src/hooks.client.ts
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
import type { HandleClientError } from "@sveltejs/kit";
|
||||||
|
|
||||||
|
export const handleError: HandleClientError = ({ error, status }) => {
|
||||||
|
const errorId = crypto.randomUUID();
|
||||||
|
|
||||||
|
console.error(`Client - Error ID: ${errorId} - Status: ${status} - ${error}`);
|
||||||
|
|
||||||
|
return {
|
||||||
|
message: 'Whoops!',
|
||||||
|
errorId,
|
||||||
|
};
|
||||||
|
};
|
|
@ -5,12 +5,11 @@ import { API_URL } from '$env/static/private';
|
||||||
import type { User } from '$lib/types';
|
import type { User } from '$lib/types';
|
||||||
|
|
||||||
export const handle: Handle = async ({ event, resolve }) => {
|
export const handle: Handle = async ({ event, resolve }) => {
|
||||||
|
|
||||||
const session = event.cookies.get('session');
|
const session = event.cookies.get('session');
|
||||||
|
|
||||||
if (!session) {
|
if (!session) {
|
||||||
event.locals.user = undefined;
|
event.locals.user = undefined;
|
||||||
return resolve(event);
|
return await resolve(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
const res = await fetch(`${API_URL}/player/`, {
|
const res = await fetch(`${API_URL}/player/`, {
|
||||||
|
@ -22,7 +21,7 @@ export const handle: Handle = async ({ event, resolve }) => {
|
||||||
if (!res.ok) {
|
if (!res.ok) {
|
||||||
event.locals.user = undefined;
|
event.locals.user = undefined;
|
||||||
event.cookies.delete('session', { path: '/' });
|
event.cookies.delete('session', { path: '/' });
|
||||||
return resolve(event);
|
return await resolve(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -33,11 +32,10 @@ export const handle: Handle = async ({ event, resolve }) => {
|
||||||
event.cookies.delete('session', { path: '/' });
|
event.cookies.delete('session', { path: '/' });
|
||||||
}
|
}
|
||||||
|
|
||||||
return resolve(event);
|
return await resolve(event);
|
||||||
};
|
};
|
||||||
|
|
||||||
export const handleFetch: HandleFetch = async ({ request, fetch, event: { cookies } }) => {
|
export const handleFetch: HandleFetch = ({ request, fetch, event: { cookies } }) => {
|
||||||
|
|
||||||
const session = cookies.get('session');
|
const session = cookies.get('session');
|
||||||
|
|
||||||
if (!session) {
|
if (!session) {
|
||||||
|
@ -53,10 +51,10 @@ export const handleFetch: HandleFetch = async ({ request, fetch, event: { cookie
|
||||||
return fetch(request);
|
return fetch(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
export const handleError: HandleServerError = async ({ error, status }) => {
|
export const handleError: HandleServerError = ({ error, status }) => {
|
||||||
const errorId = crypto.randomUUID();
|
const errorId = crypto.randomUUID();
|
||||||
|
|
||||||
console.error(`Error ID: ${errorId} - Status: ${status} - ${error}`);
|
console.error(`Server - Error ID: ${errorId} - Status: ${status} - ${error}`);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
message: 'Whoops!',
|
message: 'Whoops!',
|
||||||
|
|
|
@ -1,15 +1,14 @@
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { page } from '$app/stores';
|
import { page } from '$app/stores';
|
||||||
|
|
||||||
import Button from '$lib/components/ui/button/button.svelte';
|
import { Button } from '$lib/components/ui/button';
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="flex min-h-screen items-center justify-center">
|
<div class="flex min-h-screen items-center justify-center">
|
||||||
<div class="text-center">
|
<div class="flex flex-col gap-4 text-center">
|
||||||
<h1 class="text-6xl font-bold text-red-500">Oops!</h1>
|
<h1 class="text-6xl font-bold text-red-500">Oops!</h1>
|
||||||
<p class="mt-4 text-xl">Apparement tu as navigué en eau trouble...</p>
|
<p class="text-xl">Apparement tu as navigué en eau trouble...</p>
|
||||||
<Button class="mt-4" href="/">Retour au port</Button>
|
<Button href="/">Retour au port</Button>
|
||||||
<p class="mt-4 text-xs text-muted-foreground">{$page.error?.message}</p>
|
<span class="text-xs text-muted-foreground">Error ID: {$page.error?.errorId}</span>
|
||||||
<p class="mt-4 text-xs text-muted-foreground">{$page.error?.errorId}</p>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Add table
Reference in a new issue