Step-by-step guide
Learn how to accept payments in your React Native app using our mobile SDK. This guide explains the process of integrating the checkout experience in your app.
Checkout experience flow
The following explains the flow of a user's journey in the checkout experience.
- The term
user
used in this document refers to a customer trying to make a payment through your mobile application. - This guide assumes you named the button on your checkout screen as Checkout.
-
A user visits your app and taps Checkout.
-
Your mobile app sends the user's purchase information to your backend. Then, your backend sends this information to Dojo's backend to create a payment intent.
-
Your mobile app starts the checkout process using the mobile SDK.
-
The mobile SDK collects the user payment details, sends them to the Dojo backend, and presents a result screen to the user. The mobile SDK then notifies the hosting application of the payment result.
-
Your backend receives a webhook notification when the payment is completed.
How to process a payment
This is a step-by-step guide that demonstrates how to process payments with Dojo's backend and your backend into your mobile app using Dojo's mobile SDK.
Before you start
Before you begin to integrate, make sure you have followed the Getting started guide and got your API keys.
For the test environment, use your secret key with the prefix sk_sandbox_
.
This guide contains the following steps:
Step 1. Create a payment intent
With the checkout button in your app, call your backend and then call Dojo's backend endpoint to create a payment intent.
To create a payment intent, the following parameters are required:
-
amount
: This includes the currency and value, in minor units, for example, "1000" for 10.00 GBP. -
reference
: Your unique reference for the payment intent, like the order number.
Here's an example of how to create a payment intent for 10 GBP on your backend:
- Python
- C#
loading...
loading...
See the API reference for a complete list of parameters that can be used for payment intent creation. For configurations that apply to our mobile SDK, go to [Configurations].
Step 2. Start checkout process
Once you've created the payment intent, pass the payment intent ID to your payment flow code.
To start the checkout process, ensure you have installed the latest SDK.
- React Native
loading...
After the user fills in the payment information on the checkout screen, Dojo processes the payment and redirects the user to the result screen and your app receives a result code.
Step 3. Handle post-payment events
After a user completes a payment, we recommend using webhooks to update the backend result and receive information about the payment. Set up endpoints to receive and handle webhook requests. By using webhooks, your application can receive updates about payment events and you can ensure that you don't lose any information about the payment. To handle these events, configure your backend for incoming webhook notifications and process these notifications accordingly.
Dojo's backend sends a payment_intent.status_updated
event when the payment is completed (captured, refunded, reversed, canceled).
To set up webhooks, review our webhooks guide.
Ensure you validate the transaction result by either using a webhook or making a direct API call on your backend. The result code received on the application front-end might not be reliable as you might receive delayed responses.
Here's an example of how to subscribe to the payment_intent.status_updated
event:
- cURL
- PowerShell
- Python
- C#
- PHP
loading...
loading...
loading...
loading...
loading...
Step 4. Test and go live
Before going live, test your integration using the test card numbers:
Card Name | Card number | Expiry Date | CVV | 3D security | Status |
---|---|---|---|---|---|
No | Successful | ||||
2.0 | Successful | ||||
No | Decline |
When you are ready to go live, switch your secret key to production one with the prefix sk_prod_
.
Result Code
After integrating our SDK into your app and making a payment, you will receive a result
code. Refer to the following result codes for more information.
Result Code | Result | Description |
---|---|---|
0 | Successful | The transaction was successful. |
3 | Authorizing | The card holder hasn't completed 3DS, this status will only be seen on the REST API. |
4 | Referred | The card issuer has parked the transaction awaiting contact with the customer before proceeding to authorize or decline the transaction. |
5 | Declined | The transaction was declined by the card issuer or acquiring bank. |
20 | Duplicate Transaction | The transaction which was processed was a duplicate. Ensure each transaction has a unique OrderId. |
30 | Failed | Error executing transaction. |
400 | Invalid Request | The request has failed validation by our servers and the transaction hasn't been submitted to the gateway. Possible causes for this are invalid transaction type or other data in the request. |
401 | Issue with Access Token | The access token being used isn't valid, the transaction hasn't been submitted to the gateway. This can be caused if the token has already been used or the 30 minute expiry time has elapsed. |
404 | No Access Token Supplied | No access token has been supplied. Transaction hasn't been submitted to the gateway. |
500 | Internal Server Error | There's been an error submitting the transaction, please check the REST API for the status of the transaction. |
7770 | Sdk Internal Error | There's a problem on the SDK side. Contact Dojo for more information. |