Account holders can connect external bank accounts to Highnote for making ACH funds transfers. Highnote has partnered with Plaid and Finicity as secure, NACHA-compliant options to verify and link external accounts.
Fund-in transfers into Highnote require external account verification.
You can transfer funds into or out of Highnote from an external bank account.
There are two types of Highnote external financial accounts:
ExternalFinancialBankAccount
: Represents an account that is verified and can be used to fund in or fund out a payment.NonVerifiedExternalUSFinancialBankAccount
: Represents an account that can only be used to fund out a payment.Account Type | Transfer Method |
---|---|
ExternalFinancialBankAccount | Fund-in or Fund-out |
NonVerifiedExternalUSFinancialBankAccount | Fund-out on debit cards |
Contact your Highnote sales representative to learn more about available Plaid products and pricing for your program.
The Highnote platform offers two ways for subscribers to securely integrate with Plaid's services:
Connect verified account with Highnote: For subscribers who prefer to delegate their Plaid relationship to Highnote. In this model, Highnote works with Plaid on behalf of subscribers to securely verify end user (Highnote account holder) bank accounts.
Connect verified account with Plaid: For subscribers who prefer a direct relationship with Plaid. In this model, subscribers use Plaid to authenticate end user (Highnote account holder) bank accounts in their applications and securely pass verification details to Highnote.
Delegating your Plaid relationship to Highnote reduces your compliance requirements because Highnote provides and manages a secure vault.
As a subscriber, you can simplify your Plaid integration by enabling Highnote to securely retrieve external account information on your behalf. With a persistent access_token
, Highnote verifies end user bank accounts and then initiates and manages the ACH transfer for you.
To connect verified external accounts to Highnote:
link_token
with the Highnote API.link_token
to retrieve a public_token
.public_token
to Highnote.Highnote requests the following information on your Plaid Onboarding form:
Company / Application Details
Integration Details
Note: Highnote supports Plaid's Auth, Balance, and Identity payment products by default.
redirect_uri
or package_name
(which is the redirectUri
used in Step 3):
Note: Highnote requires a redirect URI per SDK integration even if the mutation input variable redirectUri
is optional.
Contacts
Refer to the Plaid Link documentation to integrate Plaid Link into your application.
To initiate Plaid Link (in Step 4), you must first create a Highnote link_token
. You'll use this token to generate a public_token
in Plaid.
In the Test environment, Highnote provides you with a link_token
that can be used in Plaid’s Sandbox environment to generate a public_token
. Your organization will need to be configured by Highnote for the Plaid integration.
Use the following mutation to generate a link_token
for an account holder (or end user):
To initialize Plaid Link, use the link_token
you received from Highnote (in Step 3) to generate a public_token
in Plaid. Plaid Link provides a temporary public_token
in the onSuccess
callback.
The details for passing the link_token
varies by platform. See the page for your specific platform integration: web, iOS, Android, React Native, or mobile webview.
In Highnote's Test environment, you can create a public_token
in all three of Plaid’s API environments:
Use the ProvisionAccountHolder
mutation to link an external bank account with Plaid's ephemeral public_token
. Highnote will create a persistent access_token
and use it to call various Plaid products for the account holder.
In the Test environment, provide the public_token
you received from Plaid’s Sandbox environment or one of the simulated values below.
Simulated Public Token Value | Result |
---|---|
public-token-success | Success |
public-token-no-ach-account-number | Failure |
public-token-no-routing-account-number | Failure |
public-token-wrong-sub-type | Failure |
public-token-wrong-currency-code | Failure |
public-token-wrong-length-account-number | Failure |
public-token-wrong-length-routing-number | Failure |
public-token-non-digit-routing-number | Failure |
public-token-not-found | Failure |
public-token-institution-down | Failure |
public-token-item-login-required | Failure |
Use the following query to lookup the status of linking an external bank account to the account holder.
As a subscriber, you can integrate with Highnote while maintaining your direct relationship with Plaid. You authenticate end-user bank accounts in your applications with Plaid, and then securely pass verification details to Highnote with processor_token
.
Refer to the Plaid documentation, Add Highnote to your app.
link_token
in Plaid.processor_token
by exchanging it with the link_token
.processor_token
to Highnote.Create a business or developer Plaid account. On the Plaid dashboard, go to the Keys tab and create Plaid API keys.
If a user has multiple bank accounts, the accounts
array from Plaid may contain information from all of them. Highnote requires only one bank account. To ensure the accounts
array always contains only one, go to the Plaid dashboard and set Account Select to "enabled for one account".
Follow the Plaid docs to enable your Plaid account for Highnote integration. On the Plaid dashboard:
Follow the Plaid docs to create a one-time Plaid link_token
. You will use this token to exchange it for a "Highnote" processor_token
to send to Highnote.
Follow the Plaid docs to exchange your link_token
for Plaid's "Highnote" processor_token
.
Processor token errors must be resolved with Plaid. Refer to Plaid Errors.
Use the AddExternalBankAccountVerifiedThroughPlaid
mutation to link an external bank account with Plaid's processor_token
. Highnote retrieves the account number, routing number, and account type from Plaid, and links the information to the associated account holder for future payment usage.
If the response includes a processor token error, get a new processor_token
from Plaid and reattempt adding the external bank account. All processor token errors must be resolved with Plaid. In some cases, your customer may need to resubmit their bank account credentials for you to retrieve a new processor_token
. See the Plaid docs for a list of possible Plaid-related errors.
Use the following mutation to add an external bank account using Plaid:
To test Plaid, you will need to use your processor_tokens
. You can create Highnote processor_tokens
in all three of Plaid’s API environments:
With a Finicity integration, account holders can connect verified external bank accounts within your app or website. Once an external bank account is verified, you can use Highnote to transfer money between the account holder’s external bank account and their financial account. This integration was built with security in mind and it eliminates the need for you to store sensitive information from your account holder’s external bank accounts.
Before integrating with Finicity, you must sign up for an account and create an access token:
Access Token
is shared with Highnote, it is used to securely retrieve account and routing numbers from Finicity.Note: Highnote's Finicity partner ID is 2445583993914. When testing, input this value as the thirdPartyPartnerId
.
You can test Finicity API keys in a live environment, using their preset test profiles to test for all scenarios. Finicity has also set up mock FinBanks to simulate testing against live financial institutions.
To begin testing, you must first set up your Finicity test environment. After setting up your test environment, refer to the following steps:
https://api.finicity.com/aggregation/v1/partners/accessKey
:With a Finicity Access Token
, you can call the Highnote API with the following mappings to link an external bank account:
moneyTransferDetails
-> ACH_DETAILS
availableBalanceLive
-> CURRENT_BALANCE
accountOwner
-> ACH_OWNER_DETAILS
Use the following mutation to add an external bank account with Finicity:
Note: A bank account number can be de-tokenized if it has been added using the addNonVerifiedExternalFinancialBankAccount
mutation. For bank accounts connected and verified via the addExternalBankAccountFromToken
mutation, the bank account number cannot be de-tokenized for security purposes.
External bank accounts that have not been verified by a third-party service such as Plaid or Finicity are considered to be "non-verified". Funds may only be sent to a non-verified external bank account from a Highnote financial account. Non-verified accounts may not be used to move funds into Highnote. The most common use case for non-verified external bank accounts is to return funds to an account holder in the event of account closure.
When connecting an external bank account, your account holder must provide the following external account information:
Optionally, a nickname can be assigned to the non-verified account for reference.
Use the following mutation to add a non-verified external bank account:
Note: The same mutation is used to disconnect verified and non-verified external bank accounts.
You can use the CloseExternalFinancialBankAccount
to provide the following experiences for disconnecting an external account:
Note the following guidelines for disconnecting an external bank account:
Use the following mutation to disconnect a verified or non-verified external bank account:
You can view and present a list of an account holder's external bank accounts using the following query: