Payment Intent API
The Payment Intent API allows users to purchase crypto using fiat currency (e.g., buy USDT by paying in EUR). Payments are made via bank transfer.
Once the payment is completed, the purchased crypto is sent to the wallet specified during order registration.
The API also supports KYC verification for new users if required.
Create a new Payment Intent
This method allow to register a new payment intent.
A Payment Intent records a user's intent to purchase a specified amount of crypto and pay for it using fiat. Either the crypto amount or the fiat amount is defined during the creation of the Payment Intent.
For example, if a user wants to buy €1000 worth of BTC, the system will automatically calculate the corresponding BTC amount. Similarly, if the user wants to purchase 0.01 BTC, the system will determine the required fiat amount to complete the purchase.
Therefore, it is not necessary to provide both values. If both the crypto and fiat amounts are sent via the API, the system will prioritize the fiat amount and recalculate the crypto amount accordingly.
The fiat or crypto amounts calculated by the system can be retrieved through the payment instructions API call. This allows users to review and confirm the final amounts before proceeding with the payment.
If the user is required to complete the KYC process before purchasing crypto, this API call will return a URL where they can complete the verification. Additionally, a callback URL can be specified so that, once the KYC process is successfully completed, the user is redirected back to continue the purchase process.
IPN Url and Payment Intent Status
Optionally, we can specify an IPN URL to receive asynchronous notifications whenever the payment status changes—for example, when a user pays for an order or when the cryptocurrencies are sent to the user.
The IPN Url will be called via GET with 2 parameters:
paymentIntentId: The ID of the payment intent
paymentIntentStatus: The status of the payment intent (see the payment status section to see all possible values)
Return Value
The API call will return three values:
A Payment Intent ID to reference in subsequent API calls.
A status (see the payment status section to see all possible values). However, we can only retrieve payment instructions if the status is
4
(Ready to Pay)A KYC URL (if required) where the user can complete the verification process.
To call the API, it is essential to include the x-api-key
header.
Additionally, the storeId
value, which is unique per client, must be specified for the API request to function correctly.
Both values are provided by AhoraCrypto.
Get Payment Instructions
Once the Payment Intent has been registered and the payment is ready (i.e. because the payment status was 4
Ready for Payment), we can get the payment instructions. Note that we can't call this endpoint while payment status is not ready (e.g. if the user is pending for a KYC validation). We can check the status of a payment intent by calling the Payment Intent Status endpoint at any time.
To call this API, it is essential to include the x-api-key
header.
We can retrieve the payment instructions by calling the following method:
Get Payment Status
At any time, we can check the status of a payment using this call.
Posible values are:
1
Initial state when payment intent is created but not yet processed2
Waiting for user to complete KYC (Know Your Customer) verification. User can't pay and order can't be processed until the user has passed the KYC3
Pending to pass a manual KYC verification. User has upload its documents to KYC center, but still need to be verified manually by AhoraCrypto. User can't pay and order can't be processed until the user has passed the KYC4
Ready to pay, as all previous requirements (including KYC verification) have been fulfilled.5
Payment has been received but order is still pending to be processed6
Order has been processed successfully10
Payment intent has timed out and is no longer valid12
Payment was made but has been refunded to the user14
Payment intent was cancelled before completion10000
General failure in payment / order processing10001
User failed to pass KYC verification requirements10002
The user belongs to a country that AhoraCrypto does not operated in.
It also returns an order number associated with the given payment intent ID, if it exists. Orders are created once the user has passed KYC validation and is able to pay for the order.
To call the API, it is essential to include the x-api-key
header.
We can retrieve the payment instructions by calling the following method:
Last updated