Files
Refood-One/src/hooks.server.ts
T
2026-06-04 18:51:22 +01:00

86 lines
2.1 KiB
TypeScript

import { db } from '$lib/server/db';
import * as schema from '$lib/server/db/schema';
import { eq } from 'drizzle-orm';
import { redirect, type Handle } from '@sveltejs/kit';
export const handle: Handle = async ({ event, resolve }) => {
const sessionId = event.cookies.get('session');
event.locals.user = null;
if (sessionId) {
try {
// Query session and join with user info
const result = db
.select({
session: schema.sessions,
user: schema.users
})
.from(schema.sessions)
.innerJoin(schema.users, eq(schema.sessions.userId, schema.users.id))
.where(eq(schema.sessions.id, sessionId))
.get();
if (result) {
const { session, user } = result;
if (session.expiresAt > Date.now()) {
event.locals.user = {
id: user.id,
name: user.name,
username: user.username,
role: user.role
};
} else {
// Session expired, clean up
db.delete(schema.sessions).where(eq(schema.sessions.id, sessionId)).run();
event.cookies.delete('session', { path: '/' });
}
} else {
// Invalid session cookie
event.cookies.delete('session', { path: '/' });
}
} catch (err) {
console.error('Error in session auth hook:', err);
}
}
const path = event.url.pathname;
// Route protection
if (path.startsWith('/admin') || path.startsWith('/super')) {
if (!event.locals.user) {
throw redirect(303, `/login?redirectTo=${encodeURIComponent(path)}`);
}
const role = event.locals.user.role;
if (path.startsWith('/admin/turnos')) {
if (role !== 'admin' && role !== 'shift_manager') {
if (role === 'volunteer') {
throw redirect(303, '/entregas');
}
throw redirect(303, '/login');
}
} else {
if (role !== 'admin') {
if (role === 'volunteer') {
throw redirect(303, '/entregas');
}
throw redirect(303, '/login');
}
}
}
if (path.startsWith('/entregas')) {
if (!event.locals.user) {
throw redirect(303, `/login?redirectTo=${encodeURIComponent(path)}`);
}
}
if (path === '/login' && event.locals.user) {
throw redirect(303, '/');
}
return resolve(event);
};