Endpoint
POST:{{baseURL}}/v2/payout
Supported Payment Channels
USD payouts support two payment channels:| Channel | Description | Use Case |
|---|---|---|
BANK_TRANSFER | Standard domestic bank transfer using routing number | ACH/Domestic US transfers |
SWIFT | International wire transfer using SWIFT code | International/Cross-border transfers |
Request Details
Headers
Include these headers in your request:| Header | Value | Required |
|---|---|---|
Content-Type | application/json | ✅ Yes |
x-api-key | YOUR_API_KEY | ✅ Yes |
Sample Requests
- BANK_TRANSFER
- SWIFT
Use
BANK_TRANSFER for standard domestic US bank transfers via routing number.Request Body Breakdown
- BANK_TRANSFER Fields
- SWIFT Fields
| Field | Type | Description | Required |
|---|---|---|---|
quoteId | String | The unique ID of the quote for this payout. | ✅ Yes |
reason | String | The purpose of the transfer (e.g., Gift, Payment for services). | ✅ Yes |
remark | String | An optional, additional note about the transaction. | ❔ No |
recipient | Object | An object containing all details about the person receiving the funds. | ✅ Yes |
recipient.name | String | The full name of the recipient or business. | ✅ Yes |
recipient.type | String | The type of recipient. Enum: INDIVIDUAL, BUSINESS. | ✅ Yes |
recipient.address | String | The recipient’s full residential or business address. | ✅ Yes |
recipient.paymentChannel | String | The payment method. Use BANK_TRANSFER for domestic transfers. | ✅ Yes |
recipient.currency | String | The ISO currency code. Must be USD. | ✅ Yes |
recipient.country | String | The recipient’s two-letter ISO country code. Must be US. | ✅ Yes |
recipient.stored | Boolean | A flag indicating whether to save the recipient for future use. | ❔ No |
recipient.account | Object | An object containing the recipient’s bank account details. | ✅ Yes |
recipient.account.accountNumber | String | The recipient’s bank account number. | ✅ Yes |
recipient.account.routingNumber | String | The 9-digit ABA routing transit number for the recipient’s bank. | ✅ Yes |
recipient.account.swiftCode | String | The recipient bank SWIFT code. | ❔ No |
recipient.account.bankName | String | The name of the recipient’s bank. | ✅ Yes |
recipient.account.address | String | The address of the recipient’s bank branch. | ❔ No |
Success Response (200 OK)
If the payout is successfully created, the API returns the following response:copy
Response Breakdown
| Field | Type | Description |
|---|---|---|
message | String | A confirmation message indicating the result of the request. |
status | String | The overall status of the request, e.g., success. |
data | Object | A container for all the transaction data. |
data.id | String | The unique identifier for this payout transaction. |
data.reason | String | The reason for the payout provided in the request. |
data.referenceNumber | String | A unique reference number generated for the payout. |
data.type | String | The type of transaction, e.g., SEND. |
data.state | String | The current state of the payout (COMPLETED, PENDING, etc.). |
data.quote.id | String | The unique ID of the quote used for the transaction. |
data.quote.source.currency | String | The three-letter currency code of the source funds. |
data.quote.target.amount | Number | The converted amount that the recipient received. |
data.recipient.name | String | The full name of the recipient. |
data.recipient.type | String | The type of recipient entity, e.g., BUSINESS. |
data.recipient.account.accountNumber | String | The recipient’s bank account number. |
data.recipient.account.bankName | String | The name of the recipient’s bank. |
data.recipient.account.swiftCode | String | The swift code of the recipient’s bank. |
data.created | String | ISO 8601 timestamp of when the transaction was created. |
data.processed | String | ISO 8601 timestamp of when the transaction was processed. |
Payout Transaction States
The payout transaction can have one of the following states:| State | Description |
|---|---|
COMPLETED | The payout was successfully processed. |
PENDING | The payout is still being processed. |
FAILED | The payout failed to process. |
REFUNDED | The payout has been sent back to sender. |
Error Handling
| Status Code | Meaning | Example Response |
|---|---|---|
400 | Insufficient Balance | Insufficient Balance |
401 | Unauthorized | Invalid API key provided. |
403 | Forbidden | IP not whitelisted |
404 | Not Found | The requested endpoint does not exist. |
422 | Unprocessable Entity | Invalid quote ID provided. |
500 | Internal Server Error | An internal error occurred. |
Best Practices
✅ EnsurequoteId is valid and linked to an existing quote.✅ Confirm that the recipient’s bank account number and bank code are correct.
✅ Use
BANK_TRANSFER for domestic US transfers with routing numbers.✅ Use
SWIFT for international wire transfers requiring SWIFT/BIC codes.✅ Use a valid API key in the headers.
✅ Handle error responses correctly in your integration.

