Files
sign/packages/lib/server-only/user/forgot-password.ts

53 lines
1.1 KiB
TypeScript
Raw Normal View History

2023-09-18 11:15:29 +00:00
import crypto from 'crypto';
import { prisma } from '@documenso/prisma';
2025-01-02 15:33:37 +11:00
import { ONE_DAY } from '../../constants/time';
2023-09-18 12:14:55 +00:00
import { sendForgotPassword } from '../auth/send-forgot-password';
2025-01-02 15:33:37 +11:00
export const forgotPassword = async ({ email }: { email: string }) => {
2023-09-19 13:34:54 +00:00
const user = await prisma.user.findFirst({
where: {
email: {
equals: email,
mode: 'insensitive',
},
2023-09-19 13:34:54 +00:00
},
});
2023-09-18 11:15:29 +00:00
if (!user) {
2023-09-19 13:34:54 +00:00
return;
2023-09-18 11:15:29 +00:00
}
2023-09-19 13:57:11 +00:00
// Find a token that was created in the last hour and hasn't expired
2025-01-02 15:33:37 +11:00
// const existingToken = await prisma.passwordResetToken.findFirst({
// where: {
// userId: user.id,
// expiry: {
// gt: new Date(),
// },
// createdAt: {
// gt: new Date(Date.now() - ONE_HOUR),
// },
// },
// });
// if (existingToken) {
// return;
// }
2023-09-18 11:15:29 +00:00
2023-09-19 13:34:54 +00:00
const token = crypto.randomBytes(18).toString('hex');
2023-09-18 11:15:29 +00:00
2023-09-19 13:34:54 +00:00
await prisma.passwordResetToken.create({
data: {
token,
expiry: new Date(Date.now() + ONE_DAY),
userId: user.id,
},
});
2023-09-18 11:15:29 +00:00
2023-09-19 13:34:54 +00:00
await sendForgotPassword({
2023-09-18 12:14:55 +00:00
userId: user.id,
2023-09-19 13:34:54 +00:00
}).catch((err) => console.error(err));
2023-09-18 11:15:29 +00:00
};