
* create basic app structure * add zapierSubscription model to prisma.schema * change column name triggerEvent to lower case * add zapier functionality + enpoints + adjust prisma.schema * add subscriptionType + refactor code * add app store information * create setup page to generate api key * clean code * add copy functionality in setup page * clean code * add apiKeyType and delte key when uninstalled or new key generated * clean code * use Promise.all * only approve zapier api key * clean code * fix findValidApiKey for api keys that don't expire * fix migrations * clean code * small fixes * add i18n * add README.md file * add setup guide to README.md * fix yarn.lock * Renames zapierother to zapier * Typo * Updates package name * Rename fixes * Adds zapier to the App Store seeder * Adds missing zapier to apiHandlers * Adds credential relationship to App * Rename fixes * Allows tailwind to pick up custom app-store components * Consolidates zapier_setup_instructions * Webhook fixes * Uses app relationship instead of custom type * Refactors sendPayload to accept webhook object Instead of individual parameters * refactoring * Removes unused zapier check * Update cancel.ts * Refactoring * Removes example comments * Update InstallAppButton.tsx * Type fixes * E2E fixes * Deletes all user zapier webhooks on integration removal Co-authored-by: CarinaWolli <wollencarina@gmail.com> Co-authored-by: zomars <zomars@me.com>
74 lines
1.6 KiB
TypeScript
74 lines
1.6 KiB
TypeScript
import { Prisma } from "@prisma/client";
|
|
import type { NextApiRequest, NextApiResponse } from "next";
|
|
|
|
import { getSession } from "@lib/auth";
|
|
import prisma from "@lib/prisma";
|
|
|
|
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
if (!["GET", "DELETE"].includes(req.method!)) {
|
|
return res.status(405).end();
|
|
}
|
|
|
|
// Check that user is authenticated
|
|
const session = await getSession({ req });
|
|
const userId = session?.user?.id;
|
|
|
|
if (!userId) {
|
|
res.status(401).json({ message: "You must be logged in to do this" });
|
|
return;
|
|
}
|
|
|
|
if (req.method === "GET") {
|
|
const credentials = await prisma.credential.findMany({
|
|
where: {
|
|
userId,
|
|
},
|
|
select: {
|
|
type: true,
|
|
},
|
|
});
|
|
|
|
res.status(200).json(credentials);
|
|
}
|
|
|
|
if (req.method == "DELETE") {
|
|
const id = req.body.id;
|
|
const data: Prisma.UserUpdateInput = {
|
|
credentials: {
|
|
delete: {
|
|
id,
|
|
},
|
|
},
|
|
};
|
|
const integration = await prisma.credential.findUnique({
|
|
where: {
|
|
id,
|
|
},
|
|
});
|
|
/* If the user deletes a zapier integration, we delete all his api keys as well. */
|
|
if (integration?.appId === "zapier") {
|
|
data.apiKeys = {
|
|
deleteMany: {
|
|
userId,
|
|
appId: "zapier",
|
|
},
|
|
};
|
|
/* We also delete all user's zapier wehbooks */
|
|
data.webhooks = {
|
|
deleteMany: {
|
|
userId,
|
|
appId: "zapier",
|
|
},
|
|
};
|
|
}
|
|
|
|
await prisma.user.update({
|
|
where: {
|
|
id: userId,
|
|
},
|
|
data,
|
|
});
|
|
|
|
res.status(200).json({ message: "Integration deleted successfully" });
|
|
}
|
|
}
|