2022-03-30 12:17:55 +00:00
|
|
|
import type { NextApiRequest, NextApiResponse } from "next";
|
2022-03-28 22:27:14 +00:00
|
|
|
|
2022-03-30 12:17:55 +00:00
|
|
|
import prisma from "@calcom/prisma";
|
2022-03-28 22:27:14 +00:00
|
|
|
import { Credential } from "@calcom/prisma/client";
|
|
|
|
|
|
|
|
import { schemaCredential, withValidCredential } from "@lib/validations/credential";
|
|
|
|
|
|
|
|
type ResponseData = {
|
|
|
|
data?: Credential;
|
|
|
|
message?: string;
|
|
|
|
error?: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
async function createCredential(req: NextApiRequest, res: NextApiResponse<ResponseData>) {
|
|
|
|
const { body, method } = req;
|
|
|
|
const safe = schemaCredential.safeParse(body);
|
|
|
|
if (method === "POST" && safe.success) {
|
2022-03-30 12:17:55 +00:00
|
|
|
await prisma.credential
|
|
|
|
.create({ data: safe.data })
|
|
|
|
.then((data) => res.status(201).json({ data }))
|
|
|
|
.catch((error) => res.status(400).json({ message: "Could not create credential type", error: error }));
|
|
|
|
// Reject any other HTTP method than POST
|
2022-03-28 22:27:14 +00:00
|
|
|
} else res.status(405).json({ error: "Only POST Method allowed" });
|
|
|
|
}
|
|
|
|
|
|
|
|
export default withValidCredential(createCredential);
|