Initiate Transactions on Behalf of a Customer
Businesses can perform any transaction on behalf of a customer that the customer could perform themselves. To do this, the customer's profile ID must be included in the request body. This ensures the transaction is correctly attributed to the customer rather than the business's account.
For transaction requests involving a customer, the X-BU-PROFILE-ID field should be included in the request header, and its value should be set to the customer ID for whom the request is performed on their behalf.
This guide will walk you through the process of programmatically accepting fiat currency deposits (e.g., NGN, KES) into your customer’s Busha Business fiat balances. Fiat deposits are typically facilitated through the generation of temporary bank accounts.
What You’ll Achieve:
-
Understand the specific quote requirements for fiat deposits.
-
Generate a deposit quote that provisions a temporary bank account.
-
Finalize the deposit transfer to obtain the temporary bank account details.
-
Learn how to instruct your customer to make the deposit.
-
Monitor the status of fiat deposits.
Prerequisites
Before you begin, ensure you have:
-
A Busha Business Account and Secret API Key (from the Quick Start Tutorial).
-
An understanding of API Environments (Sandbox vs. Production) and their base URLs (from the Make Your First Request Guide).
-
A conceptual understanding of Quotes (from the Understanding Quotes Explainer).
-
Familiarity with creating basic quotes (from the How to Create Your First Quote Guide)
Step 1: Get a Quote for the Fiat Deposit
Fiat deposits are initiated by creating a Quote, where the source_currency and target_currency are the same fiat currency (e.g., NGN to NGN). The key here is the pay_in object, which specifies that you intend to use a temporary_bank_account for the deposit. This informs Busha to prepare for generating such an account upon transfer finalization.
To get a fiat deposit quote:
-
Open your terminal or command prompt.
-
Construct a
POSTrequest to the/v1/quotesendpoint. -
Specify the
source_currencyandtarget_currency(both being the fiat currency you expect to receive), thesource_amountthe customer intends to deposit, and apay_inobject withtype: “temporary_bank_account”. -
Replace
{customer_id}with the customer ID. -
Replace
YOUR_BASE_URLwith your chosen environment’s URL andYOUR_SECRET_TOKENwith your actual key.
$ curl -i -X POST \
https://YOUR_BASE_URL/v1/quotes \
-H 'X-BU-PROFILE-ID: {customer_id}' \
-H 'Authorization: Bearer YOUR_SECRET_TOKEN' \
-H 'Content-Type: application/json' \
-d '{
"source_currency": "NGN",
"target_currency": "NGN",
"source_amount": "10000",
"pay_in": {
"type": "temporary_bank_account"
}
}'
A successful response will return a standard Quote object, similar to what you’ve seen before.
Note the
idof the returned Quote (e.g.,QUO_vxcF2svmjMbxDp4T5dcD8), as you will need this ID for the next step.
The pay_in object in the quote response will mirror what you sent in the request.
Step 2: Finalize the Deposit Transfer (Generate Temporary Bank Account)
After obtaining a valid Quote for a fiat deposit, you finalize the transfer. This crucial step is where Busha generates the temporary bank account details that your customer will transfer funds into. The transfer object is initiated using the POST /v1/transfers endpoint.
To finalize the deposit transfer:
-
Use the
POSTrequest below to the/v1/transfersendpoint. -
Include the
quote_idobtained from Step 1. -
Replace
{customer_id}with the customer ID. -
Replace
YOUR_BASE_URLandYOUR_SECRET_KEYwith your actual details.
$ curl -i -X POST \
https://YOUR_BASE_URL/v1/transfers \
-H 'X-BU-PROFILE-ID: {customer_id}' \
-H 'Authorization: Bearer YOUR_SECRET_KEY' \
-H 'Content-Type: application/json' \
-d '{
"quote_id": "QUO_vxcF2svmjMbxDp4T5dcD8"
}'
Sample Response with Generated Temporary Account Number:
A successful response will return a Transfer object. The generated temporary bank account number and other recipient details will be located within the data.pay_in.recipient_details object of this response.
{
"status": "success",
"message": "Created transfer successfully",
"data": {
"id": "TRF_LJB2GQb55Cs98LbpqgRMx",
"profile_id": "CUS_BqpKZiPXPo3Vz",
"quote_id": "QUO_vxcF2svmjMbxDp4T5dcD8",
"source_currency": "NGN",
"target_currency": "NGN",
"source_amount": "10000",
"target_amount": "9900",
"rate": {
"rate": "1",
"side": "sell",
"type": "FIXED",
"source_currency": "NGN",
"target_currency": "NGN"
},
"fees": [
{
"amount": {
"amount": "100",
"currency": "NGN"
},
"name": "payment gateway fee",
"type": "FIXED"
}
],
"pay_in": {
"expires_at": "2025-02-21T10:46:56.232278869Z",
"recipient_details": {
"account_name": "Payaza(Business 1 Business)",
"account_number": "7000384620",
"bank_name": "78 FINANCE COMPANY LIMITED",
"email": "dickson@busha.co"
},
"type": "temporary_bank_account"
},
"status": "pending",
"created_at": "2025-02-21T10:16:54.40130914Z",
"updated_at": "2025-02-21T10:16:54.401309215Z"
}
}
Step 3: Instruct Your User and Monitor Deposit Status
Once you have the temporary bank account details, your application should display these to the customer, along with clear instructions to make the bank transfer. After the customer initiates the transfer, you’ll need to monitor its status to confirm when the funds have been successfully deposited into your Busha balance.
To monitor deposit status:
-
Webhooks (Recommended): Set up a webhook endpoint to receive real-time notifications from Busha when the transfer status changes. This is the most efficient method for real-time updates.
-
Refer to the How to Set Up Webhook Guide for detailed instructions
-
-
Polling (Less Recommended): Periodically
GETthe transfer status using the transferid(TRF_LJB2GQb55Cs98LbpqgRMxin the example). While possible, this is less efficient and can lead to rate limiting if done too frequently.
Expected Transfer Statutes:
-
pending: Transfer initiated, awaiting user bank transfer. -
completed: Funds have been successfully received and credited to your Busha balance. -
failed: The deposit failed (e.g., transfer not received within timeframe, invalid details) -
reversed: The deposit was processed but later reversed.
Troubleshooting Common Fiat Deposit Issues
-
“Quote expired” during transfer finalization: Always create a fresh quote immediately before attempting to finalize the transfer.
-
Deposit not reflecting: Check the transfer status via API/webhooks. If still
pendingafter an extended period, contact Busha support with theTRF_ID. -
Temporary account expires: Ensure the user makes the transfer before the
pay_in.expires_attime shown in the transfer response. If expired, you may need to initiate a new deposit flow.
What’s Next?
Now that you know how to process fiat deposits, consider:
-
Exploring all relevant API endpoints: Quotes API Reference, Transfers API Reference.