Setting up Currency and Payment Protocol options for Pay-out

The currencyOptions object within the Create Payment payload, allows merchants to specify which currencies and associated protocols are available for the end user to receive payment. This object is not mandatory; however, if provided, it restricts the currencies and protocols that can be used for the transaction.

If currencyOptions is not specified, the end user will have the option to claim the payment in any of the 16 available currencies supported by our platform. A full list of supported currencies and protocols can be found at Supported Currencies API.

Example of the full JSON request payload:

{
  "merchantId": "MERCHANT_SETTLE_MID_WALLET",
  "amount": 2.0,
  "currency": "ETH",
  "reference": "REF777579",
  "type": "OUT",
  "returnUrl": "https://your-website-url.com/status",
  "customerId": "1289702",
  "flow": "PAYROLL",
  "complianceDetails": {
    "requesterIpAddress": "172.16.254.2",
    "partyDetails": [
      {
        "type": "BENEFICIARY",
        "name": "John Marion Hardy Doe",
        "entityType": "INDIVIDUAL",
        "dateOfBirth": "1983-09-23"
      }
    ]
  },
  "currencyOptions": [
    {
      "code": "ETH",
      "protocols": [
  
      ]
    },
    {
      "code": "USDT",
      "protocols": [
        "ERC20",
        "TRC20",
        "BEP20"
      ]
    }
  ]
}

Detailed Field Explanation

Structure:

"currencyOptions": [
  {
    "code": "Currency code",
    "protocols": ["List of protocols"]
  }
]

The table below outlines and explains the attributes within the complianceDetails object specifically related to the beneficiary data, including examples for a better understanding:

FieldDescriptionTypeMandatoryExample
codeThe currency code. This is a string representing the cryptocurrency code (e.g., "ETH", "USDT").stringYesETH
protocolsAn array of strings specifying the protocols supported for the specified currency. If this array is empty, all available protocols for that currency will be used. If the array contains one or more protocols, only those specified will be available for the transaction.stringNoERC20, TRC20, BEP20

Payload Examples

Example of limiting the PayOut currencies and protocols

Below is an example of a currencyOptions object limiting the transaction to ETH and USDT (ERC20 protocol only):

"currencyOptions": [
  {
    "code": "ETH",
    "protocols": []
  },
  {
    "code": "USDT",
    "protocols": ["ERC20"]
  }
]

Example with Currency Options but No Specific Protocols

This example illustrates how to include the currencyOptions object in your payload to specify which currencies can be used for the payout, without limiting the protocols for those currencies.

When the protocols array is left empty for a currency, it signifies that all available protocols for that currency are permitted. This approach allows merchants to restrict payouts to certain currencies while still offering flexibility in the choice of protocols.

{
  "currencyOptions": [
    {
      "code": "ETH",
      "protocols": []
    },
    {
      "code": "USDT",
      "protocols": []
    }
  ]
}

Example without Specified Currency and Protocol Preferences

Below is an example payload for creating a payout without specifying the currencyOptions object. In this scenario, the end user will have the option to receive the payment in any of the supported currencies, along with any available protocols for those currencies.

This flexibility allows for a broader choice for the recipient but can be limited by providing the currencyOptions object, as detailed in the Configuring Currency and Protocol Preferences on PayOut section.

{
  "merchantId": "MERCHANT_SETTLE_MID_WALLET",
  "amount": 2.0,
  "currency": "ETH",
  "reference": "REF777579",
  "type": "OUT",
  "returnUrl": "https://your-website-url.com/status",
  "customerId": "1289702",
  "flow": "PAYROLL",
  "complianceDetails": {
    "requesterIpAddress": "172.16.254.2",
    "partyDetails": [
      {
        "type": "BENEFICIARY",
        "name": "John Marion Hardy Doe",
        "entityType": "INDIVIDUAL",
        "dateOfBirth": "1983-09-23"
      }
    ]
  }
}