boredgame/oldApis/reset-password/+server.ts

35 lines
998 B
TypeScript
Raw Normal View History

import { db } from '$lib/server/api/infrastructure/database';
import { error } from '@sveltejs/kit';
import { eq } from 'drizzle-orm';
import { usersTable } from '$lib/server/api/infrastructure/database/tables';
import { createPasswordResetToken } from '$lib/server/auth-utils.js';
import { PUBLIC_SITE_URL } from '$env/static/public';
export async function POST({ locals, request }) {
const { email }: { email: string } = await request.json();
if (!locals.user) {
error(401, { message: 'Unauthorized' });
}
const user = await db.query.usersTable.findFirst({
where: eq(usersTable.email, email),
});
if (!user) {
error(200, {
message: 'Email sent! Please check your email for a link to reset your password.',
});
}
const verificationToken = await createPasswordResetToken(user.id);
const verificationLink = PUBLIC_SITE_URL + verificationToken;
// TODO: send email
console.log('Verification link: ' + verificationLink);
return new Response(null, {
status: 200,
});
}