Stripe Integration
Step 1: Create a Stripe Account
If you don’t already have a Stripe account, you can create one here.
After you have created the account, you will be redirected to the dashboard.
You are going to be asked to complete your business profile, in order to be able to receive payments, but you can skip this step if you only want to test how the implementation works.
Step 2: Create products
In order to create products, you need to go to the Product catalog
section in the Stripe dashboard.
You will be able to see a “Create product” button, that will allow you to create a new product.
We will create 3 products, that will represent the amount of coins that the user can buy in the application:
- 50 coins
- 200 coins
- 500 coins
Make sure that the products have the “One-off” payment type. You can set any price you want for the products.
In a visual way, this is how the process should look like:
- Stripe dashboard with no products inside the product catalog
- Click on the “Create product” button and add a product details
- After you have created the products, you should see them in the product catalog
Step 3: Integrate inside the NodeJS server
After we have the products created, we need to get the Stripe secrey key and the product keys and add them inside the .env
file in the NodeJS server.
You can find the secret key in the Stripe dashboard, in the Developers section. (Developers -> API keys from the header) The product keys can be found in the product details, in the Stripe dashboard.
Let’s see how it should look like:
- Find the secret key
You will be redirected to the API keys section, where you can find the secret key.
- Find the product keys
Make sure that you have the product ids from all the products that you have created.
After you have the keys, you need to add them inside the .env
file in the NodeJS server.
STRIPE_SECRET_KEY=sk_test_51JG
STRIPE_PRODUCT_50_COINS=price_1JG
STRIPE_PRODUCT_200_COINS=price_1JG
STRIPE_PRODUCT_500_COINS=price_1JG
Step 4: Integrate inside the Web Application
Inside the Web Application, you need to add the Stripe public key inside the .env
file.
You can find the public key in the Stripe dashboard, in the Developers section. (Developers -> API keys from the header).
It should be above the secret key (Publishable key).
Add this inside the .env
file in the root of the Web Application:
NEXT_PUBLIC_STRIPE_PUBLIC_KEY=pk_test_51JG
Step 5: Add Stripe Webhook
In order to receive the payment status, you need to add a webhook inside the Stripe dashboard. This webhook will send a POST request to the server every time a payment is made.
You can add a webhook by going to the Developers section in the Stripe dashboard and clicking on the “Webhooks” section.
You will be able to see a “Add endpoint” button, that will allow you to add a new webhook.
You need to add the URL of the server, followed by /payment/stripe-webhook
.
For example, if the server is running on http://localhost:7777
, the webhook URL should be http://localhost:7777/payment/stripe-webhook
.
The problem when using localhost is that Stripe will not be able to send the POST request to the server, because it is running on your local machine.
One option is to use a service like ngrok to create a tunnel to your local machine.
The official option of testing the webhook is using the Stripe CLI. You can find more information about this here.
For demo purposes, I will be using ngrok to create a tunnel to my local machine. This will provide me with a public URL that I can use to test the webhook.
- Create a new webhook
- Choose what events to be send through the webhook. The NodeJS server only handles the “checkout.session.completed” event, so you can select only this event.
- After the webhook is created, you need to add the “Signing secret” of this webhook inside the
.env
file in the NodeJS server.
This is what you need to add inside the .env
file in the NodeJS server:
STRIPE_WEBHOOK_SIGNING_SECRET=your_signing_secret
Do not forget that if you remove a webhook and create a new one, you need to update the signing secret inside the .env
file.
Step 6: Test the integration
Make sure that every time you change the .env
file, you restart the server.
The integration should work by default now. You can test it by going to the application and trying to buy coins.
If you’re testing the integration, you can use the test card number 4242 4242 4242 4242
with any expiration date and CVC.
If you want to receive payments inside a production environment, you need to complete the business profile in the Stripe dashboard.
When going in production, do not forget to create another webhook for the production server and update the .env
accordingly.