Search...
APIJSLog inGet started in sandbox
Airwallex logo
Home
Platform APIs
Connected Accounts
Accounts
Payments
Billing
Transactional FX
Payouts
Issuing
Back to home
OverviewUnderstanding Global Treasury
Market & infrastructure coverage
Use cases
Get started
Set up your platform accountGlobal Accounts
Linked Accounts
Linked Account statusesManage Linked Accounts
Revenue and fees
Test and go live

Linked Accounts

A Linked Account is a verified external financial account (such as a bank account, credit/debit card, or e-wallet account) that is bound to an Airwallex account. Currently, we only support linking bank accounts owned by the business that signed up for the Airwallex account, or one of its Ultimate Beneficial Owners (UBOs). Learn how to use Airwallex API API to set up a linked bank account and add funds via direct debits.

Before you begin

  • Obtain your access token API by authenticating to Airwallex using your unique Client ID and API key. You will need the access token to make API calls.
  • Contact your Airwallex Account Manager to enable Linked Account APIs on your Airwallex account.
  • Set up webhooks to receive notifications on Deposit events (currently only available for direct debit deposits).
  • As a platform, you can call all Linked Accounts API endpoints on behalf of your connected accounts by specifying the connected account's open ID (in the format acct_xxxxxxxx) in the x-on-behalf-of header of your API request. To learn about how you can register as a platform and set up this solution, see Global Treasury and Banking as a Service solutions.

To successfully link an external bank account, Airwallex must first verify its ownership. Airwallex offers two options to verify the external bank account:

  • Open Banking: Verify by securely entering your credentials in an Open Banking modal, or approving an authorization from your external banking application. Currently, this is available for Linked Accounts in Australia, Canada, Europe (SEPA region), the United States, the United Kingdom and Singapore.
  • Micro-deposits: Verify by entering the micro-deposit amounts sent to your external bank account.

We recommend Open Banking, as it allows you to complete the process in just a few minutes. Using PLAID and TRUELAYER also enables you to Check available balances API before creating direct debit deposits. However, if your external bank account is in a region or with a bank not supported by Open Banking, please proceed to use micro-deposits.

Please note that Open Banking in Australia via PayTo works differently from other regions. See Australia (AU_PAYTO_DEBIT) for more details on how to create a Linked Account via PayTo in Australia.

Open Banking verification typeSupported Linked Account types
PLAIDUS_BANK, CA_BANK
TRUELAYEREU_BANK, GB_BANK
EGIROSG_BANK

For Singapore eGIRO and Australia PayTo, only Linked Accounts verified using Open Banking can add funds via direct debit, as the Linked Bank Account owner must provide authorization through their banking app. If you are creating a linked account to add funds via direct debit in the aforementioned countries, please keep this in mind.

Create a Linked Account using Open Banking verification

Get an Open Banking authentication token

Airwallex works with external partners to offer Open Banking for account verifications. Please contact your Account Manager to receive instructions to set up an Open Banking modal on your own front-end experience. The integration uses Airwallex API endpoints, and you do not need to contact or contract with our Open Banking partners separately.

Call Generate a Linked Account authentication API to retrieve a Link Token required to access the Open Banking modal.

Provide the following parameters in your request:

  • type: Specify a verification type for your external bank account.

Plaid verification

If the type is PLAID:

  • country_code: The country the external bank account is located.
  • client_name: The name of your business to be displayed in the modal.
  • redirect_url: URL that the user will be redirected to at the end of the Plaid modal. Please also provide this URL to your Account Manager.
Example request
Shell
Example response
JSON

TrueLayer verification

If the type is TRUELAYER:

  • country_code: The country the external bank account is located.
  • provider_id: Unique ID of the external financial institution as provided by Truelayer here .
  • redirect_url: URL that the user will be redirected to at the end of the TrueLayer modal. Please also provide this URL to your Account Manager.

eGIRO verification

If the type is EGIRO:

  • swift_code: 11-digit SWIFT code of the external bank account.
    • An UNAVAILABLE_BANK_CODE error will be returned when the specified bank does not support eGIRO. For such cases, you may create a linked account without direct debit enabled using micro-deposit verification instead.
  • entity_type: BUSINESS or INDIVIDUAL.
  • redirect_url: URL that the user will be redirected to at the end of the eGIRO modal.
  • reference: Unique mandate ID specified in the request, which will appear on the authorization request to the payer on their banking app. Only accept alphanumeric characters in all caps without spacing, up to 35 characters long.

EGIRO itself functions as a direct debit scheme; hence, to create a Linked Account via eGIRO, you must collect mandate authorization from your customers and submit that information in Create a Linked Account API. If you do not intend to use the Linked Account for adding funds via Direct Debit, then it's recommended to Create the Linked Account via micro-deposit verification instead.

Create a Linked Account

Call Create a Linked Account API specifying the external bank account location under Linked Account type (e.g. US_BANK) and corresponding bank account information, including information obtained from your Open Banking modal.

Before you can add funds via direct debit from a Linked Account, you must obtain authorization from the external bank account owner in the form of a signed mandate (or signed agreement). You may submit mandate information while creating a Linked Account, or later by calling Update a direct debit mandate API.

You can subscribe to Linked Account webhook events to receive any Linked Account status transitions. See Linked Account statuses for more information.

To create and sign direct debit mandates via API, as a first step, please contact your Airwallex Account Manager to walk you through the scheme-specific direct debit schemes and mandate requirements and to enable this capability for your use case.

Provide the following parameters in your request:

  • type: Type of Linked Account.
  • Details about the specific Linked Account. When using Open Banking, you only need to provide entity_type and currency.
  • preferred_verification_type: Type of verification used to link your external account.
  • Open Banking details about the specific Linked Account, such as token information to grant Airwallex access to account details.
  • Mandate details, if you plan to use direct debit later.

Create Linked Account via Plaid

For PLAID as the preferred_verification_type, you should provide the following details parsed from the Plaid Modal’s onSuccess callback:

  • public_token: The Plaid public token
  • institution:
    • id: Plaid’s unique identifier of the external bank account’s financial institution
    • name: Name of the external bank account’s financial institution
  • account:
    • id: Plaid’s unique identifier of the external bank account
    • mask: The last 2-4 alphanumeric characters of the external bank account’s account number
    • name: Name of the external bank account
Example request
Shell

If you are registered as a platform account, you can call this endpoint on behalf of your customers by specifying the open ID in the x-on-behalf-of header.

Example response
JSON

Create Linked Account via TrueLayer

For TRUELAYER as the preferred_verification_type, you should provide the following details parsed from TrueLayer’s onSuccess callback:

  • code: code retrieved from TrueLayer's callback URL
  • state: state retrieved from TrueLayer’s callback URL
Example request
Shell

If you are registered as a platform account, you can call this endpoint on behalf of your customers by specifying the open ID in the x-on-behalf-of header.

During the Open Banking experience with TrueLayer, the user is permitted to select more than one financial account under the same bank credentials. If this happens, you will need to identify a single account to link with Airwallex.

When calling Create a Linked Account API or Get a Linked Account by ID API, you will see the Linked Account status as REQUIRES_ACTION, with confirm_account returned under the next_action object. Under candidate_accounts, you will see a list of all financial accounts that have been successfully verified and can be converted into a Linked Account.

Example response
JSON

To select the Linked Account you would like to create, call Confirm a Linked Account among candidate accounts API and input the corresponding account_identity.

Example request
Shell

If you are registered as a platform account, you can call this endpoint on behalf of your customers by specifying the open ID in the x-on-behalf-of header.

If only one account was selected in the TrueLayer authentication, the Linked Account will be created right away.

Create Linked Account via eGIRO

For EGIRO as the preferred_verification_type, you should provide the following details parsed from the callback URL:

  • auth_id: auth_id returned in the callback URL
  • auth_reference: auth_reference returned in the callback URL
Example request
Shell

If you are registered as a platform account, you can call this endpoint on behalf of your customers by specifying the open ID in the x-on-behalf-of header.

Example response
JSON

Listed below are the possible statuses after you verify the Linked Account.

StatusDescription
PROCESSINGLinked Account activation is in progress. The customer should wait for the status to update.
SUCCEEDEDLinked Account has been created successfully.
FAILEDThe request to create a Linked Account was unsuccessful.

Refresh an expired Linked Account

Linked Accounts verified by Open Banking could expire if the external bank account owner changes their login credentials, revokes our access to their account, or naturally after a long period of time (typically above one year).

If the status of your Linked account returns as REQUIRES_ACTION, call Refresh a Linked Account authentication API to acquire a new Link Token for your Open Banking modal.

Example response

JSON

Once the Linked Account owner has completed the Open Banking modal, call Complete the Authentication Refresh API to reactivate your Linked Account. You do not need another Public Token for this request.

Create a Linked Account using micro-deposit verification

Create a Linked Account

Call Create a Linked Account API specifying the external bank account location in Linked Account type (e.g. AU_BANK, US_BANK) and corresponding bank account information. Set MICRO_DEPOSIT as your preferred_verification_type.

Before you can add funds via direct debit from a Linked Account, you must obtain authorization from the external bank account owner in the form of a signed mandate (or signed agreement). You may submit mandate information while creating a Linked Account, or later by calling Update a direct debit mandate API.

You can subscribe to Linked Account webhook events to receive any Linked Account status transitions. See Linked Account statuses for more information.

To create and sign direct debit mandates via API, as a first step, please contact your Airwallex Account Manager to walk you through the scheme-specific direct debit schemes and mandate requirements and to enable this capability for your use case.

Provide the following parameters in your request:

  • type: Type of Linked Account.
  • Details about the specific Linked Account.
  • preferred_verification_type: Type of verification used to link your external account.
  • Mandate details, if you plan to use direct debit later.

Example request

Shell

If you are registered as a platform account, you can call this endpoint on behalf of your customers by specifying the open ID in the x-on-behalf-of header.

Verify by entering micro-deposit amounts

After submitting a Create a Linked Account API request, you should receive REQUIRES_ACTION in the status parameter within the response.

  • REQUIRES_ACTION: Indicates that customer action such as verifying the Linked Account with micro-deposits is pending. Inspect the parameters in the next_action object, which provides details of the next action to be taken to activate the Linked Account.
    • micro_deposit_count: Number of micro-deposits sent to the linked bank account.
    • remaining_attempts: Remaining attempts left to enter the correct micro-deposit amount. When this becomes 0, the status field will be updated to FAILED.
    • type: Type of action to be taken, e.g, verify_micro_deposits.

Call Verify a Linked Account with micro-deposits API using your Linked Account ID in the URL. Specify the two micro-deposits in the amounts[] request parameter, in any order.

When the verification of the Linked Account is complete, Airwallex returns the status as SUCCEEDED. If you submitted a direct debit mandate with type GB_BACS_DEBIT, please also wait 3-4 days for the mandate to be activated, during which your Linked Account status will remain as PROCESSING.

Review status codes to track status transitions when Linked Accounts are created and verified.

Example request

Shell

If you are registered as a Scale platform account, you can call this endpoint on behalf of your connected accounts by specifying the open ID in the x-on-behalf-of header.

Retrieve details of your Linked Account

To retrieve details for a specific Linked Account, call Get a Linked Acount by ID API by specifying Linked Account ID in the endpoint URL.

You can subscribe to Linked Account webhook events to receive any Linked Account status transitions. See Linked Account statuses for more information.

Example request

Shell

If you are registered as a platform account, you can call this endpoint on behalf of your customers by specifying the open ID in the x-on-behalf-of header.

Example response

JSON

You can also retrieve all Linked Accounts associated with your Airwallex account using Get a list of Linked Accounts API. If you want to filter the results, provide additional parameters for time period (from_created_at, to_created_at), pagination (page_size, page_num), status, and/or country_code of the account.

Example request

Shell

If you are registered as a platform account, you can call this endpoint on behalf of your customers by specifying the open ID in the x-on-behalf-of header.

Example response

JSON
Was this page helpful?
On this page
Was this page helpful?