I'm trying to get the line_items of the checkout session in Stripe so that I can send an email consisting of the product download link but unfortunately, When I try to retrieve the line_items
in the checkout_session
I get a null value.
Frontend: Next.js
Here is my code in /pages/api/webhooks/index.ts
:
Check the line: 77
import { buffer } from "micro";
import Cors from "micro-cors";
import { NextApiRequest, NextApiResponse } from "next";
import Stripe from "stripe";
const stripe = new Stripe(process.env.STRIPE_SECRET_KEY!, {
// https://github.com/stripe/stripe-node#configuration
apiVersion: "2020-08-27",
});
const webhookSecret: string = process.env.STRIPE_WEBHOOK_SECRET!;
// Stripe requires the raw body to construct the event.
export const config = {
api: {
bodyParser: false,
},
};
const cors = Cors({
allowMethods: ["POST", "HEAD"],
});
const webhookHandler = async (req: NextApiRequest, res: NextApiResponse) => {
if (req.method === "POST") {
const buf = await buffer(req);
const sig = req.headers["stripe-signature"]!;
let event: Stripe.Event;
try {
event = stripe.webhooks.constructEvent(
buf.toString(),
sig,
webhookSecret
);
} catch (err) {
// On error, log and return the error message.
console.log(`β Error message: ${err.message}`);
res.status(400).send(`Webhook Error: ${err.message}`);
return;
}
// Successfully constructed event.
console.log(`β
Success: ${event.id}`);
// Cast event data to Stripe object.
if (event.type === "payment_intent.created") {
const paymentIntent = event.data.object as Stripe.PaymentIntent;
console.log(`π° PaymentIntent status: ${paymentIntent.status}`);
console.log('-----------------------------------------------------');
} else if (event.type === "payment_intent.payment_failed") {
const paymentIntent = event.data.object as Stripe.PaymentIntent;
console.log(
`β Payment failed: ${paymentIntent.last_payment_error?.message}`
);
console.log('-----------------------------------------------------');
} else if (event.type === "customer.created") {
const customer = event.data.object as Stripe.Customer;
console.log(`Customer created: ${customer.id}`);
console.log('-----------------------------------------------------');
} else if(event.type === 'payment_intent.requires_action') {
const paymentIntent = event.data.object as Stripe.PaymentIntent;
console.log(`β Payment requires action: ${paymentIntent.id}`);
} else if (event.type === "payment_intent.succeeded") {
const paymentIntent = event.data.object as Stripe.PaymentIntent;
console.log(`π° Payment succeeded: ${paymentIntent.id}`);
console.log('-----------------------------------------------------');
} else if (event.type === "charge.succeeded") {
const charge = event.data.object as Stripe.Charge;
console.log(`π΅ Charge id: ${charge.id}`);
console.log('-----------------------------------------------------');
} else if (event.type === "checkout.session.completed") {
const checkout_session = event.data.object as Stripe.Checkout.Session;
console.log(`π³ Session id: ${checkout_session.id}`);
console.log(`Customer email: ${checkout_session.customer_details.email}`);
console.log(`Order products: ${checkout_session.line_items}`);
console.log('-----------------------------------------------------');
} else {
console.warn(`π€·ββοΈ Unhandled event type: ${event.type}`);
console.log('-----------------------------------------------------');
}
// Return a response to acknowledge receipt of the event.
res.json({ received: true });
} else {
res.setHeader("Allow", "POST");
res.status(405).end("Method Not Allowed");
}
};
export default cors(webhookHandler as any);
When I try to log the line_items
in the checkout_session
I get a null value.