In-App Purchases
You can use Stripe anywhere in your app by importing thestripe
object like so:
page.tsx
Webhooks
Stripe webhooks are handled in thePOST /webhooks/stripe
route in the api
app. This route constructs the event and then switches on the event type to determine how to process the event.
Local Development
To test webhooks locally, we’ve configured the Stripe CLI to forward webhooks to your local server. This will start automatically when you runpnpm dev
.
Anti-Fraud
As your app grows, you will inevitably encounter credit card fraud. Stripe Radar is enabled by default if you integrate payments using their SDK as described above. This provides a set of tools to help you detect and prevent fraud. Stripe Radar supports more advanced anti-fraud features if you embed the Stripe JS script in every page load. This is not enabled by default in JTBDOS, but you can add it as follows:1
Edit the layout
Edit
apps/app/app/layout.tsx
and add <Script src="https://js.stripe.com/v3/" />
after the opening <html>
tag and before the opening <body>
tag. You will also need to add import Script from 'next/script'
2
Add script to the website
Add the same script to the website in
apps/web/app/layout.tsx
.3
Prevent common fraud patterns with Arcjet
Prevent common fraud patterns by using Arcjet IP address analysis to block requests from VPNs and proxies. These are commonly used by fraudsters to hide their location, but have legitimate uses as well so are not blocked by default. You could simply block these users, or you could adjust the checkout process to require approval before processing their payment.
apps/app/app/(authenticated)/layout.tsx
you could add this after the call to aj.protect()
: