Stripe is the default billing provider in both the local config and the DB, so you don't need to set these values if you want to use Stripe.
For Stripe, you'll need to set the following environment variables:
STRIPE_SECRET_KEY=
STRIPE_WEBHOOK_SECRET=
NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY=
While the NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY
is public and can be added anywhere - please do not add the secret keys to the .env
file.
During development, you can place them in .env.local
as it's not committed to the repository. In production, you can set them in the environment variables of your hosting provider.
Stripe CLI
The Stripe CLI which allows you to listen to Stripe events straight to your own localhost. You can install and use the CLI using a variety of methods, but we recommend using Docker - since you already have it installed.
First - login to your Stripe account using the project you want to run:
docker run --rm -it --name=stripe -v ~/.config/stripe:/root/.config/stripe stripe/stripe-cli:latest login
Copy the webhook secret displayed in the terminal and set it as the STRIPE_WEBHOOK_SECRET
environment variable in your .env.local
file:
STRIPE_WEBHOOK_SECRET=*your_webhook_secret*
Now, you can listen to Stripe events running the following command:
pnpm run stripe:listen
If you have not logged in - the first time you set it up, you are required to sign in. This is a one-time process. Once you sign in, you can use the CLI to listen to Stripe events.
Please sign in and then re-run the command. Now, you can listen to Stripe events.
If you're not receiving events, please make sure that:
- the webhook secret is correct
- the account you signed in is the same as the one you're using in your app
Configuring the Stripe Customer Portal
Stripe requires you to set up the Customer Portal so that users can manage their billing information, invoices and plan settings from there.
- Please make sure to enable the setting that lets users switch plans
- Configure the behavior of the cancellation according to your needs
Setting Production Webhooks in Stripe
When going to production, you will need to set the webhook URL and the events you want to listen to in Stripe.
The webhook path is /api/billing/webhook
. If your app is hosted at https://myapp.com
then you need to enter https://myapp.com/api/billing/webhook
.
Makerkit needs the following events to work:
checkout.session.completed
customer.subscription.updated
customer.subscription.deleted
Only if you're using one-off payments, please add:
checkout.session.async_payment_failed
checkout.session.async_payment_succeeded
If your application needs more events, please add them, but remember to handle them.
You can handle additional events by adding the required handlers in the api/billing/webhook/route.ts
file.