import type { NextApiRequest, NextApiResponse } from "next"; import { stringify } from "querystring"; import { WEBAPP_URL } from "@calcom/lib/constants"; import getAppKeysFromSlug from "../../_utils/getAppKeysFromSlug"; import { encodeOAuthState } from "../../_utils/oauth/encodeOAuthState"; export default async function handler(req: NextApiRequest, res: NextApiResponse) { let clientId = ""; const appKeys = await getAppKeysFromSlug("zohocrm"); if (typeof appKeys.client_id === "string") clientId = appKeys.client_id; if (!clientId) return res.status(400).json({ message: "zohocrm client id missing." }); const state = encodeOAuthState(req); const params = { client_id: clientId, response_type: "code", redirect_uri: `${WEBAPP_URL}/api/integrations/zohocrm/callback`, scope: ["ZohoCRM.modules.ALL", "ZohoCRM.users.READ", "AaaServer.profile.READ"], access_type: "offline", state, prompt: "consent", }; const query = stringify(params); const url = `https://accounts.zoho.com/oauth/v2/auth?${query}`; res.status(200).json({ url }); }