19 implement i18n #29
3 changed files with 34 additions and 36 deletions
22
src/lib/server/auth/index.ts
Normal file
22
src/lib/server/auth/index.ts
Normal file
|
|
@ -0,0 +1,22 @@
|
|||
import { redirect, type ServerLoadEvent } from '@sveltejs/kit';
|
||||
import dayjs from 'dayjs';
|
||||
import { prisma } from '../prisma';
|
||||
|
||||
export async function validateSession(event: ServerLoadEvent) {
|
||||
const sessionId = event.cookies.get('auth_session');
|
||||
if (!sessionId) {
|
||||
redirect(300, '/login');
|
||||
}
|
||||
const session = await prisma.session.findUnique({
|
||||
where: { id: sessionId },
|
||||
include: { user: true },
|
||||
});
|
||||
if (!session) {
|
||||
redirect(300, '/login');
|
||||
}
|
||||
const expiry = session.expiresAt;
|
||||
if (dayjs(expiry).isBefore(dayjs())) {
|
||||
redirect(300, '/login');
|
||||
}
|
||||
return session;
|
||||
}
|
||||
|
|
@ -1,18 +1,10 @@
|
|||
import { prisma } from '$lib/server/prisma';
|
||||
import { redirect } from '@sveltejs/kit';
|
||||
import { validateSession } from '$lib/server/auth/index.js';
|
||||
|
||||
export async function load(event) {
|
||||
const sessionId = event.cookies.get('auth_session');
|
||||
if (!sessionId) {
|
||||
redirect(303, '/login');
|
||||
}
|
||||
const user = await prisma.session.findUnique({
|
||||
where: {
|
||||
id: sessionId,
|
||||
},
|
||||
});
|
||||
if (!user) {
|
||||
redirect(300, '/login');
|
||||
}
|
||||
return {};
|
||||
}
|
||||
const {
|
||||
user: { password: _, ...rest },
|
||||
} = await validateSession(event);
|
||||
return {
|
||||
user: rest,
|
||||
};
|
||||
}
|
||||
|
|
@ -1,25 +1,9 @@
|
|||
import { prisma } from '$lib/server/prisma';
|
||||
import { redirect } from '@sveltejs/kit';
|
||||
import dayjs from 'dayjs';
|
||||
import { validateSession } from '$lib/server/auth/index.js';
|
||||
|
||||
export async function load(event) {
|
||||
const sessionId = event.cookies.get('auth_session');
|
||||
if (!sessionId) {
|
||||
redirect(300, '/login');
|
||||
}
|
||||
const session = await prisma.session.findUnique({
|
||||
where: { id: sessionId },
|
||||
include: { user: true },
|
||||
});
|
||||
if (!session) {
|
||||
redirect(300, '/login');
|
||||
}
|
||||
const expiry = session.expiresAt;
|
||||
if (dayjs(expiry).isBefore(dayjs())) {
|
||||
redirect(300, '/login');
|
||||
}
|
||||
|
||||
const { password: _, ...rest } = session.user;
|
||||
const {
|
||||
user: { password: _, ...rest },
|
||||
} = await validateSession(event);
|
||||
return {
|
||||
user: rest,
|
||||
};
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue