50 lines
1.5 KiB
TypeScript
50 lines
1.5 KiB
TypeScript
|
import type { NextApiRequest, NextApiResponse } from "next";
|
||
|
|
||
|
import prisma from "@calcom/prisma";
|
||
|
|
||
|
import appConfig from "../config.json";
|
||
|
|
||
|
// TODO: There is a lot of code here that would be used by almost all apps
|
||
|
// - Login Validation
|
||
|
// - Looking up credential.
|
||
|
// - Creating credential would be specific to app, so there can be just createCredential method that app can expose
|
||
|
// - Redirection after successful installation can also be configured by app
|
||
|
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" });
|
||
|
}
|
||
|
// TODO: Define appType once and import everywhere
|
||
|
const slug = appConfig.slug;
|
||
|
const appType = appConfig.type;
|
||
|
try {
|
||
|
const alreadyInstalled = await prisma.credential.findFirst({
|
||
|
where: {
|
||
|
appId: slug,
|
||
|
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,
|
||
|
appId: slug,
|
||
|
},
|
||
|
});
|
||
|
if (!installation) {
|
||
|
throw new Error(`Unable to create user credential for type ${type}`);
|
||
|
}
|
||
|
} catch (error: unknown) {
|
||
|
if (error instanceof Error) {
|
||
|
console.error(error.message);
|
||
|
return res.status(500).json({ message: error.message });
|
||
|
}
|
||
|
return res.status(500);
|
||
|
}
|
||
|
|
||
|
return res.status(200).json({ url: "/apps/installed" });
|
||
|
}
|