79 lines
2.5 KiB
TypeScript
79 lines
2.5 KiB
TypeScript
// Next.js API route support: https://nextjs.org/docs/api-routes/introduction
|
|
import type {NextApiRequest, NextApiResponse} from "next";
|
|
import {app} from "@/firebase";
|
|
import {getFirestore, setDoc, doc, getDocs, query, collection, where} from "firebase/firestore";
|
|
import {withIronSessionApiRoute} from "iron-session/next";
|
|
import {sessionOptions} from "@/lib/session";
|
|
import {Type, User} from "@/interfaces/user";
|
|
import {PERMISSIONS} from "@/constants/userPermissions";
|
|
import {uuidv4} from "@firebase/util";
|
|
import {prepareMailer, prepareMailOptions} from "@/email";
|
|
import * as Stripe from "stripe";
|
|
import ShortUniqueId from "short-unique-id";
|
|
import moment from "moment";
|
|
|
|
const db = getFirestore(app);
|
|
|
|
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
const {email, days, key, checkout} = req.body as {email: string; days: string; key: string; checkout: string};
|
|
if (!key || key !== process.env.STRIPE_KEY) {
|
|
res.status(403).json({ok: false});
|
|
return;
|
|
}
|
|
|
|
const uid = new ShortUniqueId();
|
|
const code = uid.randomUUID(6);
|
|
|
|
const codeCheckerRef = await getDocs(query(collection(db, "codes"), where("checkout", "==", checkout)));
|
|
if (codeCheckerRef.docs.length !== 0) {
|
|
res.status(401).json({ok: false});
|
|
return;
|
|
}
|
|
|
|
const emailCheckerRef = await getDocs(query(collection(db, "users"), where("email", "==", email)));
|
|
if (emailCheckerRef.docs.length !== 0) {
|
|
const user = emailCheckerRef.docs[0];
|
|
if (!user.data().subscriptionExpirationDate) {
|
|
res.status(200).json({ok: true});
|
|
return;
|
|
}
|
|
|
|
const codeUserRef = await getDocs(query(collection(db, "codes"), where("userId", "==", user.id)));
|
|
const userCode = codeUserRef.docs[0];
|
|
|
|
if (userCode.data().checkout && userCode.data().checkout === checkout) {
|
|
res.status(401).json({ok: false});
|
|
return;
|
|
}
|
|
|
|
await setDoc(
|
|
user.ref,
|
|
{subscriptionExpirationDate: moment(user.data().subscriptionExpirationDate).add(days, "days").toISOString()},
|
|
{merge: true},
|
|
);
|
|
await setDoc(userCode.ref, {checkout}, {merge: true});
|
|
|
|
res.status(200).json({ok: true});
|
|
return;
|
|
}
|
|
|
|
const codeRef = doc(db, "codes", code);
|
|
await setDoc(codeRef, {type: "student", code, expiryDate: moment(new Date()).add(days, "days").toISOString(), checkout});
|
|
|
|
const transport = prepareMailer();
|
|
const mailOptions = prepareMailOptions(
|
|
{
|
|
type: "student",
|
|
code,
|
|
environment: process.env.ENVIRONMENT,
|
|
},
|
|
[email],
|
|
"EnCoach Registration",
|
|
"main",
|
|
);
|
|
|
|
await transport.sendMail(mailOptions);
|
|
|
|
res.status(200).json({ok: true});
|
|
}
|