62 lines
1.8 KiB
TypeScript
62 lines
1.8 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, collection, getDocs } from "firebase/firestore";
|
|
import { withIronSessionApiRoute } from "iron-session/next";
|
|
import { sessionOptions } from "@/lib/session";
|
|
import axios from "axios";
|
|
import { v4 } from "uuid";
|
|
import { OrderResponseBody } from "@paypal/paypal-js";
|
|
import { getAccessToken } from "@/utils/paypal";
|
|
|
|
const db = getFirestore(app);
|
|
|
|
export default withIronSessionApiRoute(handler, sessionOptions);
|
|
|
|
async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
if (req.method !== "PUT")
|
|
return res.status(404).json({ ok: false, reason: "Method not supported!" });
|
|
|
|
if (!req.session.user) return res.status(401).json({ ok: false });
|
|
|
|
const accessToken = await getAccessToken();
|
|
if (!accessToken)
|
|
return res.status(401).json({ ok: false, reason: "Authorization failed!" });
|
|
|
|
const trackingId = `${req.session.user.id}-${Date.now()}`;
|
|
|
|
const url = `${process.env.PAYPAL_ACCESS_TOKEN_URL}/v1/risk/transaction-contexts/${process.env.PAYPAL_MERCHANT_ID}/${trackingId}`;
|
|
const data = {
|
|
additional_data: [
|
|
{
|
|
key: "user_id",
|
|
value: req.session.user.id,
|
|
},
|
|
],
|
|
};
|
|
|
|
const headers = {
|
|
headers: {
|
|
Authorization: `Bearer ${accessToken}`,
|
|
},
|
|
};
|
|
console.log(JSON.stringify({
|
|
url,
|
|
data,
|
|
headers,
|
|
}));
|
|
try {
|
|
const request = await axios.put(url, data, headers);
|
|
|
|
return res.status(request.status).json({
|
|
ok: true,
|
|
trackingId,
|
|
});
|
|
} catch (err) {
|
|
console.error(url, err);
|
|
return res
|
|
.status(500)
|
|
.json({ ok: false, reason: "Failed to create tracking ID" });
|
|
}
|
|
}
|