Files
sign/apps/web/pages/api/users/index.ts

54 lines
1.4 KiB
TypeScript
Raw Normal View History

2023-01-07 15:11:15 +01:00
import type { NextApiRequest, NextApiResponse } from "next";
2023-05-28 13:11:09 +10:00
import { hashPassword } from "@documenso/lib/auth";
2023-04-04 22:02:32 +00:00
import { defaultHandler, defaultResponder, getUserFromToken } from "@documenso/lib/server";
import prisma from "@documenso/prisma";
2023-01-07 15:11:15 +01:00
2023-01-09 17:10:36 +01:00
async function postHandler(req: NextApiRequest, res: NextApiResponse) {
2023-01-07 15:11:15 +01:00
const { method, body } = req;
2023-01-09 17:10:36 +01:00
if (!body.email) {
return res.status(400).json({ message: "Email cannot be empty." });
2023-01-07 15:11:15 +01:00
}
2023-01-09 17:10:36 +01:00
let newUser: any;
newUser = await prisma.user
.create({
data: { email: body.email },
})
.then(async () => {
return res.status(201).send(newUser);
});
2023-01-07 15:11:15 +01:00
}
2023-01-09 17:10:36 +01:00
2023-01-25 12:26:19 +01:00
async function patchHandler(req: NextApiRequest, res: NextApiResponse) {
const user = await getUserFromToken(req, res);
if (!user) return;
const updatedUser = req.body;
2023-05-28 13:11:09 +10:00
let password: string | undefined = undefined;
if (typeof updatedUser.password === "string" && updatedUser.password.length >= 6) {
password = await hashPassword(updatedUser.password);
}
2023-01-25 12:26:19 +01:00
await prisma.user
.update({
where: {
id: user.id,
},
data: {
name: updatedUser.name,
2023-05-28 13:11:09 +10:00
password,
2023-01-25 12:26:19 +01:00
},
})
.then(() => {
return res.status(200).end();
});
}
2023-01-09 17:10:36 +01:00
export default defaultHandler({
POST: Promise.resolve({ default: defaultResponder(postHandler) }),
2023-01-25 12:26:19 +01:00
PATCH: Promise.resolve({ default: defaultResponder(patchHandler) }),
2023-01-09 17:10:36 +01:00
});