feat: create a password reset token

This commit is contained in:
Ephraim Atta-Duncan
2023-09-18 11:15:29 +00:00
committed by Mythie
parent 3544e44c31
commit 729d0c93fe
5 changed files with 171 additions and 6 deletions

View File

@ -0,0 +1,52 @@
import crypto from 'crypto';
import { prisma } from '@documenso/prisma';
import { TForgotPasswordFormSchema } from '@documenso/trpc/server/profile-router/schema';
export const forgotPassword = async ({ email }: TForgotPasswordFormSchema) => {
const user = await prisma.user.findFirstOrThrow({
where: {
email: email.toLowerCase(),
},
});
if (!user) {
throw new Error('A password reset email has been sent.');
}
const existingToken = await prisma.passwordResetToken.findFirst({
where: {
userId: user.id,
createdAt: {
gte: new Date(Date.now() - 1000 * 60 * 60),
},
},
});
if (existingToken) {
throw new Error('A password reset email has been sent.');
}
const token = crypto.randomBytes(64).toString('hex');
const expiry = new Date();
expiry.setHours(expiry.getHours() + 24); // Set expiry to one hour from now
let passwordResetToken;
try {
passwordResetToken = await prisma.passwordResetToken.create({
data: {
token,
expiry,
userId: user.id,
},
});
} catch (error) {
throw new Error('Something went wrong');
}
console.log('Password reset token: ', passwordResetToken);
// send an email to user with password token
return passwordResetToken;
};