import type { NextApiRequest, NextApiResponse } from "next"; import prisma from "@calcom/prisma"; import { withMiddleware } from "@lib/helpers/withMiddleware"; import { BookingReferenceResponse, BookingReferencesResponse } from "@lib/types"; import { schemaBookingCreateBodyParams, schemaBookingReferenceReadPublic, } from "@lib/validations/booking-reference"; async function createOrlistAllBookingReferences( { method, userId, body }: NextApiRequest, res: NextApiResponse ) { const userWithBookings = await prisma.user.findUnique({ where: { id: userId }, include: { bookings: true }, }); if (!userWithBookings) throw new Error("User not found"); const userBookingIds = userWithBookings.bookings.map((booking: { id: number }) => booking.id).flat(); if (method === "GET") { /** * @swagger * /booking-references: * get: * operationId: listBookingReferences * summary: Find all booking references * tags: * - booking-references * responses: * 200: * description: OK * 401: * description: Authorization information is missing or invalid. * 404: * description: No booking references were found */ const data = await prisma.bookingReference.findMany({ where: { id: { in: userBookingIds } } }); const booking_references = data.map((bookingReference) => schemaBookingReferenceReadPublic.parse(bookingReference) ); if (booking_references) res.status(200).json({ booking_references }); else (error: Error) => res.status(404).json({ message: "No BookingReferences were found", error, }); } else if (method === "POST") { /** * @swagger * /booking-references: * post: * operationId: addBookingReference * summary: Creates a new booking reference * requestBody: * description: Create a new booking reference related to one of your bookings * required: true * content: * application/json: * schema: * type: object * required: * - type * - uid * - meetindId * - bookingId * - deleted * properties: * deleted: * type: boolean * example: false * uid: * type: string * example: '123456789' * type: * type: string * example: email@example.com * bookingId: * type: number * example: 1 * meetingId: * type: string * example: 'meeting-id' * tags: * - booking-references * responses: * 201: * description: OK, booking reference created * 400: * description: Bad request. BookingReference body is invalid. * 401: * description: Authorization information is missing or invalid. */ const safe = schemaBookingCreateBodyParams.safeParse(body); if (!safe.success) { res.status(400).json({ message: "Bad request. BookingReference body is invalid", error: safe.error }); return; // throw new Error("Invalid request body"); } const userWithBookings = await prisma.user.findUnique({ where: { id: userId }, include: { bookings: true }, }); if (!userWithBookings) { throw new Error("User not found"); } const userBookingIds = userWithBookings.bookings.map((booking: { id: number }) => booking.id).flat(); if (!safe.data.bookingId) throw new Error("BookingReference: bookingId not found"); if (!userBookingIds.includes(safe.data.bookingId)) res.status(401).json({ message: "Unauthorized" }); else { const booking_reference = await prisma.bookingReference.create({ data: { ...safe.data }, }); if (booking_reference) { res.status(201).json({ booking_reference, message: "BookingReference created successfully", }); } else { (error: Error) => res.status(400).json({ message: "Could not create new booking reference", error, }); } } } else res.status(405).json({ message: `Method ${method} not allowed` }); } export default withMiddleware("HTTP_GET_OR_POST")(createOrlistAllBookingReferences);