
* WIP bookings page ui changes, created api endpoint * Ui changes mobile/desktop * Added translations * Fix lib import and common names * WIP reschedule * WIP * Save wip * [WIP] builder and class for CalendarEvent, email for attende * update rescheduled emails, booking view and availability page view * Working version reschedule * Fix for req.user as array * Added missing translation and refactor dialog to self component * Test for reschedule * update on types * Update lib no required * Update type on createBooking * fix types * remove preview stripe sub * remove unused file * remove unused import * Fix reschedule test * Refactor and cleaning up code * Email reschedule title fixes * Adding calendar delete and recreate placeholder of cancelled * Add translation * Removed logs, notes, fixed types * Fixes process.env types * Use strict compare * Fixes type inference * Type fixing is my middle name * Update apps/web/components/booking/BookingListItem.tsx * Update apps/web/components/dialog/RescheduleDialog.tsx * Update packages/core/builders/CalendarEvent/director.ts * Update apps/web/pages/success.tsx * Updates rescheduling labels * Update packages/core/builders/CalendarEvent/builder.ts * Type fixes * Update packages/core/builders/CalendarEvent/builder.ts * Only validating input blocked once * E2E fixes * Stripe tests fixes * Wipe my cal init commit * Fixes circular dependencies * Added conditional display for wipe my cal button * Added placeholder image for app category * Fix type string for conditional validation Co-authored-by: Peer Richelsen <peer@cal.com> Co-authored-by: zomars <zomars@me.com>
42 lines
1.2 KiB
TypeScript
42 lines
1.2 KiB
TypeScript
import type { NextApiRequest, NextApiResponse } from "next";
|
|
|
|
import prisma from "@calcom/prisma";
|
|
|
|
/**
|
|
* This is an example endpoint for an app, these will run under `/api/integrations/[...args]`
|
|
* @param req
|
|
* @param res
|
|
*/
|
|
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
if (!req.session?.user?.id) {
|
|
return res.status(401).json({ message: "You must be logged in to do this" });
|
|
}
|
|
const appType = "wipemycal_other";
|
|
try {
|
|
const alreadyInstalled = await prisma.credential.findFirst({
|
|
where: {
|
|
type: appType,
|
|
userId: req.session.user.id,
|
|
},
|
|
});
|
|
if (alreadyInstalled) {
|
|
throw new Error("Already installed");
|
|
}
|
|
const installation = await prisma.credential.create({
|
|
data: {
|
|
type: appType,
|
|
key: {},
|
|
userId: req.session.user.id,
|
|
},
|
|
});
|
|
if (!installation) {
|
|
throw new Error("Unable to create user credential for wipe-my-cal");
|
|
}
|
|
} catch (error: unknown) {
|
|
if (error instanceof Error) {
|
|
return res.status(500).json({ message: error.message });
|
|
}
|
|
return res.status(500);
|
|
}
|
|
return res.redirect("/apps/installed");
|
|
}
|