
* refactor: emails (WIP) * wip * wip * refactor: calendarClient * chore: remove comment * feat: new templates * feat: more templates (wip) * feat: email templates wip * feat: email templates wip * feat: prepare for testing * For testing stripe integration * Uses imported BASE_URL * Fixes types * use BASE_URL Co-authored-by: Omar López <zomars@me.com> Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com>
50 lines
1.4 KiB
TypeScript
50 lines
1.4 KiB
TypeScript
import type { NextApiRequest, NextApiResponse } from "next";
|
|
import { stringify } from "querystring";
|
|
|
|
import { getSession } from "@lib/auth";
|
|
import { BASE_URL } from "@lib/config/constants";
|
|
import prisma from "@lib/prisma";
|
|
|
|
const client_id = process.env.STRIPE_CLIENT_ID;
|
|
|
|
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
if (req.method === "GET") {
|
|
// Check that user is authenticated
|
|
const session = await getSession({ req: req });
|
|
|
|
if (!session) {
|
|
res.status(401).json({ message: "You must be logged in to do this" });
|
|
return;
|
|
}
|
|
|
|
// Get user
|
|
const user = await prisma.user.findUnique({
|
|
where: {
|
|
id: session.user?.id,
|
|
},
|
|
select: {
|
|
email: true,
|
|
name: true,
|
|
},
|
|
});
|
|
|
|
const redirect_uri = encodeURI(BASE_URL + "/api/integrations/stripepayment/callback");
|
|
const stripeConnectParams = {
|
|
client_id,
|
|
scope: "read_write",
|
|
response_type: "code",
|
|
"stripe_user[email]": user?.email,
|
|
"stripe_user[first_name]": user?.name,
|
|
redirect_uri,
|
|
};
|
|
const query = stringify(stripeConnectParams);
|
|
/**
|
|
* Choose Express or Stantard Stripe accounts
|
|
* @url https://stripe.com/docs/connect/accounts
|
|
*/
|
|
// const url = `https://connect.stripe.com/express/oauth/authorize?${query}`;
|
|
const url = `https://connect.stripe.com/oauth/authorize?${query}`;
|
|
|
|
res.status(200).json({ url });
|
|
}
|
|
}
|