Admin Passwort in die db und in Backen konfiguriebar

This commit is contained in:
titver968
2025-04-17 16:00:18 +02:00
parent 06693cf59a
commit b3c7113ce4
11 changed files with 366 additions and 16 deletions

View File

@@ -0,0 +1,30 @@
import { json } from '@sveltejs/kit';
import type { RequestHandler } from './$types';
import { PrismaClient } from '@prisma/client';
import bcrypt from 'bcryptjs';
const prisma = new PrismaClient();
function checkAuth(cookies: any) {
return cookies.get('admin_session') === 'true';
}
export const POST: RequestHandler = async ({ request, cookies }) => {
if (!checkAuth(cookies)) return new Response('Nicht erlaubt', { status: 401 });
const { oldPassword, newPassword } = await request.json();
const admin = await prisma.admin.findUnique({ where: { id: 1 } });
if (!admin) return json({ error: 'Admin nicht gefunden' }, { status: 500 });
const isValid = await bcrypt.compare(oldPassword, admin.password);
if (!isValid) return json({ error: 'Falsches Passwort' }, { status: 401 });
const newHashed = await bcrypt.hash(newPassword, 10);
await prisma.admin.update({
where: { id: 1 },
data: { password: newHashed }
});
return json({ success: true });
};