42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
import type { NextApiRequest, NextApiResponse } from "next";
|
|
import paymentCheckout from "@/lib/api/paymentCheckout";
|
|
import { Plan } from "@/types/global";
|
|
import { getToken } from "next-auth/jwt";
|
|
import { prisma } from "@/lib/api/db";
|
|
|
|
export default async function users(req: NextApiRequest, res: NextApiResponse) {
|
|
const STRIPE_SECRET_KEY = process.env.STRIPE_SECRET_KEY;
|
|
const MONTHLY_PRICE_ID = process.env.MONTHLY_PRICE_ID;
|
|
const YEARLY_PRICE_ID = process.env.YEARLY_PRICE_ID;
|
|
|
|
const token = await getToken({ req });
|
|
|
|
if (!STRIPE_SECRET_KEY || !MONTHLY_PRICE_ID || !YEARLY_PRICE_ID)
|
|
return res.status(400).json({ response: "Payment is disabled." });
|
|
|
|
console.log(token);
|
|
|
|
if (!token?.id) return res.status(404).json({ response: "Token invalid." });
|
|
|
|
const email = (await prisma.user.findUnique({ where: { id: token.id } }))
|
|
?.email;
|
|
|
|
if (!email) return res.status(404).json({ response: "User not found." });
|
|
|
|
let PRICE_ID = MONTHLY_PRICE_ID;
|
|
|
|
if ((Number(req.query.plan) as Plan) === Plan.monthly)
|
|
PRICE_ID = MONTHLY_PRICE_ID;
|
|
else if ((Number(req.query.plan) as Plan) === Plan.yearly)
|
|
PRICE_ID = YEARLY_PRICE_ID;
|
|
|
|
if (req.method === "GET") {
|
|
const users = await paymentCheckout(
|
|
STRIPE_SECRET_KEY,
|
|
email as string,
|
|
PRICE_ID
|
|
);
|
|
return res.status(users.status).json({ response: users.response });
|
|
}
|
|
}
|