Bank account setup (v3 API)
Bank account setup in your BILL organization with the BILL v3 API is a three-step process.
- Create a bank account with
POST /v3/funding-accounts/banks
. - Verify the bank account with
POST /v3/funding-accounts/banks/{bankAccountId}/verify
. - Ensure that the bank account user is verified to use the bank account.
See the /v3/funding-accounts/banks API for the complete list of available operations. You can also set up a bank account with the BILL web app. See Bank account setup (BILL web app) for more information.
Creating a bank account is an MFA-trusted operationCreating a bank account requires an MFA-trusted API session. See MFA setup in the API reference for information about the BILL MFA process.
Bank accounts best practices
We recommend that you follow the best practices checklist when setting up bank accounts with the BILL v3 API.
- Test with different account numbers: When you create a test bank account, use different test
routingNumber
andaccountNumber
combinations. Avoid using the same numbers across different test BILL organizations. - Complete bank account verification: After you create a test bank account, complete the bank account verification step. This helps with better managing your test bank accounts.
Create a bank account
In your POST /v3/funding-accounts/banks
request, set the required fields.
Field | Description |
---|---|
nameOnAccount | Full name on bank account |
routingNumber | Bank account routing number. For testing, enter any valid routing number. For example, 074000010 . |
accountNumber | Bank account number |
type | Bank account type (CHECKING or SAVINGS ) |
ownerType | Bank account owner type (BUSINESS or PERSONAL ) |
bankName | Bank name. Set this field as a nickname for your bank account. |
See the /v3/funding-accounts/banks API for the complete list of available operations.
Sample request
In this cURL example, a bank account is set up with the specified details. The new bank account is created in the BILL organization that the currently signed-in user has access to.
curl --request POST \
--url 'https://gateway.stage.bill.com/connect/v3/funding-accounts/banks' \
--header 'content-type: application/json' \
--header 'devKey: {developer_key}' \
--header 'sessionId: {session_id}' \
--data '{
"nameOnAccount": "Agatha Ffringe",
"routingNumber": "074000010",
"accountNumber": "111222333",
"type": "CHECKING",
"ownerType": "BUSINESS",
"bankName": "Chase"
}'
Response
In the response, a BILL-generated bank account id
is available. The value begins with bac
. You can use this bank account id
for other BILL operations, such as setting it as a funding account source when you create a payment with POST /v3/payments
. See Payments for more information.
{
"id": "{bankaccount_id}",
"archived": true,
"status": "PENDING",
"createdBy": "{user_id}",
"routingNumber": "074000010",
"accountNumber": "*****2333",
"nameOnAccount": "Agatha Ffringe",
"type": "CHECKING",
"ownerType": "BUSINESS",
"bankName": "Chase",
"default": {
"payables": false,
"receivables": false
},
"createdTime": "2025-12-16T23:15:23.127+00:00",
"updatedTime": "2025-12-16T23:15:23.127+00:00"
}
Bank account verification in productionIn the production environment, when you create a bank account with the API, BILL sends a test ACH payment to the bank account to confirm whether the account details are accurate. BILL takes up to 2 business days to send the test payment.
Use this ACH payment value to verify your bank account with
POST /v3/funding-accounts/banks/{bankAccountId}/verify
.
In the response, three fields are set to their default values.
- The bank account
status
is set asPENDING
. You can verify the bank account withPOST /v3/funding-accounts/banks/{bankAccountId}/verify
. - The
payables
andreceivables
values are set asfalse
. To update these values, update the bank account withPATCH /v3/funding-accounts/banks/{bankAccountId}
.
See the /v3/funding-accounts/banks API for more information.
Verify a bank account
In your POST /v3/funding-accounts/banks/{bankAccountId}/verify
request, set the required fields.
When you create a bank account, BILL sends a test ACH payment to the bank account to confirm whether the account details are accurate. Enter the test amount as the depositAmount
value in your POST /v3/funding-accounts/banks/{bankAccountId}/verify
request.
Bank account verification in sandboxWhen you create a bank account with the API in the production environment, you must complete bank account verification before the account can be used for other BILL operations.
In the sandbox environment, set
depositAmount
as0.50
in yourPOST /v3/funding-accounts/banks/{bankAccountId}/verify
request to complete bank account verification.
Field | Description |
---|---|
bankAccountId | BILL-generated ID of the bank account. The value begins with bac . |
depositAmount | Verify deposit amount. Enter an amount between 0.01 and 0.99 . |
See the /v3/funding-accounts/banks/{bankAccountId}/verify API for more information.
Sample request
In this cURL example, the bank account verification is initiated. In the request, depositAmount
is set as the test ACH payment sent by BILL when the bank account was created.
curl --request POST \
--url 'https://gateway.stage.bill.com/connect/v3/funding-accounts/banks/{bankAccountId}/verify' \
--header 'content-type: application/json' \
--header 'devKey: {developer_key}' \
--header 'sessionId: {session_id}' \
--data '{
"depositAmount": 0.50
}'
Response
In the response, the bank account verification status is available.
{
"verified": true
}
The bank account status
is set as VERIFIED
when BILL is able to verify the depositAmount
value. When BILL cannot verify the bank account after three attempts, you cannot use the bank account. At that point, use another bank account or create a bank account with POST /v3/funding-accounts/banks
.
See the /v3/funding-accounts/banks/{bankAccountId}/verify API for more information.
Bank account user must be verified
After your bank account verification is complete, ensure that the current bank account user verificationStatus
is set as VERIFIED
before you can use the bank account.
Confirm the verificationStatus
of the user with GET /v3/funding-accounts/banks/users
. To begin the verification process for the user, nominate a bank account user with POST /v3/funding-accounts/banks/users/nominate
.
When you nominate a user, BILL performs a set of operations.
- The bank account user
verificationStatus
is set asNOMINATED
. - BILL sends the user an email asking them to sign in to the BILL web app and complete identity verification.
After user identity verification is successful, the bank account user verificationStatus
is set as VERIFIED
and the user can pay with the specified bank account.
See the /v3/funding-accounts/banks/users/nominate API for more information.
Updated 21 days ago