 02b935bcde
			
		
	
	
		02b935bcde
		
			
		
	
	
	
	
		
			
			* 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" });
 | |
|   }
 | |
| }
 |