Pay with a Customer Wallet
On this page, you will find a guide on how to allow your customer to use their wallet amount to execute payments, how to top up their wallet, and how to directly use their balance as the payment method.
Wallet operations
For every option we will present, you need to start at the creation of the intent using the Create Intent endpoint:
Showing the customer's wallet
Your customer may use the amount they have in their wallet only when it is larger than the total payment amount. To be able to present your customers with their wallet, you need to add to the payload the respective customer's unique identifier:
Property | Type | Description |
---|---|---|
amount | Number | The amount to charge in the payment process. |
amount_currency | String | The currency of the amount is represented by a string of alphabetic codes from ISO 4217 Currency codes. |
operation | String | The type of the current intent. It can be one of purchase , authorize , or capture . |
webhook_url | String | A URL that the MoneyHash server will send a POST request to you when needed. |
customer | String | The unique identifier of the customer. |
{
"amount": 50,
"amount_currency": "usd",
"customer": "c6c42108-293f-44c9-92fc-5d6ef2003b33",
"operation": "purchase",
"webhook_url": "https://webhook.site/b8954509-f628-4805-a4b4-58a0fb2be958"
}
For the example above, if the customer has a wallet amount larger than 50 USD, the wallet option will be presented as a payment method option.
Include wallet balance while paying with any method
If the customer has a wallet amount that is less than the total intent amount, they can use the balance to pay partially with other methods.
This is supported with our SDKs and as part of our embed experience.
Using a wallet directly
To directly choose the customer's wallet to execute the payment during the creation of the intent, you need to add the following fields to the payload:
Property | Type | Description |
---|---|---|
amount | Number | The amount to charge in the payment process. |
amount_currency | String | The currency of the amount is represented by a string of alphabetic codes from ISO 4217 Currency codes. |
operation | String | The type of the current intent. It can be one of purchase , authorize , or capture . |
webhook_url | String | A URL that the MoneyHash server will send a POST request to you when needed. |
customer | String | The unique identifier of the customer. |
use_wallet | Boolean | Adding this flag as true will execute the payment with the customer's wallet amount without presenting the payment method selection to the customer. |
{
"amount": 50,
"amount_currency": "usd",
"use_wallet": true,
"customer": "11dedf5a-92ea-4cca-8a48-a711a49f26dd",
"webhook_url": "https://webhook.site/b8954509-f628-4805-a4b4-58a0fb2be958"
}
Top up a customer's wallet
MoneyHash allows your customer to top up the amount available in their wallet. To do this, you need to create an intent and add the following fields:
Property | Type | Description |
---|---|---|
amount | Number | The amount to charge in the payment process. |
amount_currency | String | The currency of the amount is represented by a string of alphabetic codes from ISO 4217 Currency codes. |
operation | String | The type of the current intent. It can be one of purchase , authorize , or capture . |
webhook_url | String | A URL that the MoneyHash server will send a POST request to you when needed. |
customer | String | The unique identifier of the customer. |
top_up_wallet | Boolean | A flag that indicates the intention to top up the wallet amount with the respective intent. |
{
"amount": 50,
"amount_currency": "usd",
"top_up_wallet": true,
"customer": "11dedf5a-92ea-4cca-8a48-a711a49f26dd",
"webhook_url": "https://webhook.site/b8954509-f628-4805-a4b4-58a0fb2be958"
}
The intent created here allows your customer to execute a payment as any other, not to buy something but to store the amount paid in their wallet in MoneyHash's system.
From here, you are able to proceed with any integration except the HPP one.
Keep track of the webhook endpoint you sent within the request to see the progress of the payment process.
Updated 3 months ago