56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
// Next.js API route support: https://nextjs.org/docs/api-routes/introduction
|
|
import type {NextApiRequest, NextApiResponse} from "next";
|
|
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";
|
|
|
|
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"});
|
|
}
|
|
}
|