Endpoint
POST /merchants/transactions/b2c
Description
Initiates a fund transfer to the user’s DCash account. The transaction flow works as follows:
Transfer to DCash
Funds are transferred from your merchant account to the user’s DCash account
Withdraw to Provider
If payment provider is provided in the request, funds are withdrawn from the user’s DCash account and sent to the specified payment provider. Otherwise, the funds remain in the user’s DCash account
Complete
Transaction completes and response is returned
Body Parameters
Merchant-provided unique identifier for the transaction
Brief description of the withdrawal
Provider to process the withdrawal (e.g., “mpesa”, “airtel”)
Currency code (e.g., “USD”)
Response
Unique identifier for the transaction
Merchant-provided reference ID (if provided)
Status of the transaction (e.g., “completed”)
Timestamp of completion (format: YYYYMMDDHHMMSS)
Example Request
curl --request POST \
--url https://sandbox.dcash.africa/merchants/transactions/b2c \
--header 'Content-Type: application/json' \
--header 'x-api-key: YOUR_MERCHANT_API_KEY' \
--data '{
"reference_id": "abcd",
"description": "Test withdrawal",
"payment_provider": "mpesa",
"email": "test.user@dcash.africa",
"amount": 10,
"currency": "USD"
}'
Example Response
{
"transaction_id": "skjr7",
"reference_id": "abcd",
"transaction_status": "completed",
"amount": 10,
"currency": "USD",
"date_completed": 20250401125109
}
Important Notes
Ensure you have sufficient balance in your merchant account before initiating withdrawals.
Unlike deposits, withdrawals typically complete synchronously and return the full transaction details in the immediate response.
Use Cases
Common scenarios for B2C withdrawals:
- Payouts: Sending earnings or rewards to users
- Refunds: Processing refund requests
- Cashouts: Allowing users to withdraw their balance
- Disbursements: Distributing funds to multiple recipients
Error Codes
| Code | Message |
|---|
missing_api_key | please provide an api key |
invalid_api_key | api key does not exist |
invalid_email | invalid email address |
user_not_found | user not found |
invalid_currency | invalid currency |
user_not_active | user not active |
user_balance_not_found | user balance not found |
merchant_not_active | merchant not active |
merchant_balance_not_found | merchant balance not found |
invalid_amount | invalid amount |
insufficient_balance | insufficient balance |
reference_already_used | a transaction with the reference id exists |
internal_server_error | internal server error |