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 { Schedule } from "@calcom/prisma/client";
|
|
|
|
|
|
|
|
import { schemaSchedule, withValidSchedule } from "@lib/validations/schedule";
|
2022-03-30 12:17:55 +00:00
|
|
|
import {
|
|
|
|
schemaQueryIdParseInt,
|
|
|
|
withValidQueryIdTransformParseInt,
|
|
|
|
} from "@lib/validations/shared/queryIdTransformParseInt";
|
2022-03-28 22:27:14 +00:00
|
|
|
|
|
|
|
type ResponseData = {
|
|
|
|
data?: Schedule;
|
|
|
|
message?: string;
|
|
|
|
error?: unknown;
|
|
|
|
};
|
|
|
|
|
|
|
|
export async function editSchedule(req: NextApiRequest, res: NextApiResponse<ResponseData>) {
|
|
|
|
const { query, body, method } = req;
|
|
|
|
const safeQuery = await schemaQueryIdParseInt.safeParse(query);
|
|
|
|
const safeBody = await schemaSchedule.safeParse(body);
|
|
|
|
|
|
|
|
if (method === "PATCH" && safeQuery.success && safeBody.success) {
|
2022-03-30 12:17:55 +00:00
|
|
|
const data = await prisma.schedule.update({
|
|
|
|
where: { id: safeQuery.data.id },
|
|
|
|
data: safeBody.data,
|
|
|
|
});
|
2022-03-28 22:27:14 +00:00
|
|
|
if (data) res.status(200).json({ data });
|
2022-03-30 12:17:55 +00:00
|
|
|
else
|
|
|
|
res
|
|
|
|
.status(404)
|
|
|
|
.json({ message: `Event type with ID ${safeQuery.data.id} not found and wasn't updated`, error });
|
2022-03-28 22:27:14 +00:00
|
|
|
|
|
|
|
// Reject any other HTTP method than POST
|
2022-03-30 12:17:55 +00:00
|
|
|
} else res.status(405).json({ message: "Only PATCH Method allowed for updating schedules" });
|
2022-03-28 22:27:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export default withValidQueryIdTransformParseInt(withValidSchedule(editSchedule));
|