Link a bank account
Link a bank account to an existing Moov account. Read our bank accounts guide to learn more.
It is strongly recommended that callers include the X-Wait-For header, set to payment-method, if the newly linked
bank-account is intended to be used right away. If this header is not included, the caller will need to poll the List Payment
Methods
endpoint to wait for the new payment methods to be available for use.
To access this endpoint using an access token
you’ll need to specify the /accounts/{accountID}/bank-accounts.write scope.
 | 
 | 
 | 
 | 
{
  "bankAccountID": "833fa3ef-14d3-4c97-ba45-6af66f739832",
  "bankAccountType": "checking",
  "bankName": "Gringotts Bank",
  "fingerprint": "dd4cbfe5fbaf47b392770b5b595bec604fd99394749b7d017153e2b9cfbea40e",
  "holderName": "John Doe",
  "holderType": "individual",
  "lastFourAccountNumber": "6789",
  "routingNumber": "123456780",
  "status": "new",
  "statusReason": "bank-account-created",
  "updatedOn": "2024-11-26T22:37:06Z"
}Response headers
x-request-id
      string
      <uuid>
    
      required
    
  {
  "error": "string"
}Response headers
x-request-id
      string
      <uuid>
    
      required
    
  Response headers
x-request-id
      string
      <uuid>
    
      required
    
  Response headers
x-request-id
      string
      <uuid>
    
      required
    
  Response headers
x-request-id
      string
      <uuid>
    
      required
    
  {
  "error": "string"
}Response headers
x-request-id
      string
      <uuid>
    
      required
    
  {
  "account": "string",
  "error": "string",
  "mx": "string",
  "plaid": "string",
  "plaidLink": "string"
}Response headers
x-request-id
      string
      <uuid>
    
      required
    
  Response headers
x-request-id
      string
      <uuid>
    
      required
    
  Response headers
x-request-id
      string
      <uuid>
    
      required
    
  Response headers
x-request-id
      string
      <uuid>
    
      required
    
  Headers
x-moov-version
      string
      
    
  API version
Specify an API version.
API versioning follows the format vYYYY.QQ.BB, where
YYYYis the yearQQis the two-digit month for the first month of the quarter (e.g., 01, 04, 07, 10)BBis the build number, starting at.01, for subsequent builds in the same quarter.- For example, 
v2024.01.00is the initial release of the first quarter of 2024. 
- For example, 
 
The latest version represents the most recent development state. It may include breaking changes and should be treated as a beta release.
v2024.01.00x-wait-for
      string
      
    
  Optional header to wait for certain events, such as the creation of a payment method, to occur before returning a response.
When this header is set to payment-method, the response will include any payment methods that were created for the newly
linked card in the paymentMethods field. Otherwise, the paymentMethods field will be omitted from the response.
payment-method,
      
        rail-response
      
    Path parameters
accountID
      string
      <uuid>
    
      required
    
  Body
account
        object
      
    
    
      
      
    
    
    
    
  Show child attributes
accountNumber
        string
      
    
    
      
      
    
    
      required
    
    
    
  bankAccountType
        string<enum>
      
    
    
      
      
    
    
      required
    
    
    
  checking,
    
      savings,
    
      general-ledger,
    
      loan
    
  holderName
        string
      
    
    
      
      
    
    
      required
    
    
    
  holderType
        string<enum>
      
    
    
      
      
    
    
      required
    
    
    
  individual,
    
      business
    
  routingNumber
        string
      
    
    
      
      
    
    
      required
    
    
    
  plaid
        object
      
    
    
      
      
    
    
    
    
  The details of a Plaid processor integration for a linked funding source.
sandbox - When linking a bank account to a sandbox account using a Plaid processor token a default bank account
response will be used. The following default data will be used to generate the bank account in this flow:
 | 
 | 
Show child attributes
token
        string
      
    
    
      
      
    
    
      required
    
    
    
  This is used by Moov.js with a Plaid reseller relationship.
Describes the account to link to the Moov account using a Plaid using a Plaid public token.
plaidLink
        object
      
    
    
      
      
    
    
    
    
  This is used by Moov.js with a Plaid reseller relationship. The details of a Plaid link integration for a linked funding source.
You can simulate linking bank accounts with Plaid in test mode. See our test mode guide for more information.
Plaid’s sandbox environment - (requires Plaid reseller setup with Moov). When linking a bank account to a sandbox account using a Plaid
public token it will utilize Plaid’s sandbox environment. The Plaid public token provided must be generated from Plaid’s sandbox environment.
Please see Plaid’s sandbox documentation for more
details.
Show child attributes
publicToken
        string
      
    
    
      
      
    
    
      required
    
    
    
  Describes the account to link to the Moov account using a MX processor token.
sandbox - When linking a bank account to a sandbox account using an MX authorization token a default bank account routing number will
be used. The following default data will be used to generate the bank account in this flow:
 | 
 | 
mx
        object
      
    
    
      
      
    
    
    
    
  The authorization code of a MX account which allows a processor to retrieve a linked payment account.
sandbox - When linking a bank account to a sandbox account using a MX authorization code it will utilize MX’s sandbox environment.
The MX authorization code provided must be generated from MX’s sandbox environment.
Show child attributes
authorizationCode
        string
      
    
    
      
      
    
    
      required
    
    
    
  Response
bankAccountID
        string<uuid>
      
    
    
      
      
    
    
      required
    
    
    
  bankAccountType
        string<enum>
      
    
    
      
      
    
    
      required
    
    
    
  checking,
    
      savings,
    
      general-ledger,
    
      loan
    
  bankName
        string
      
    
    
      
      
    
    
      required
    
    
    
  fingerprint
        string
      
    
    
      
      
        <=100 characters
      
    
    
      required
    
    
    
  Once the bank account is linked, we don’t reveal the full bank account number.
The fingerprint acts as a way to identify whether two linked bank accounts are the same.
holderName
        string
      
    
    
      
      
    
    
      required
    
    
    
  holderType
        string<enum>
      
    
    
      
      
    
    
      required
    
    
    
  individual,
    
      business
    
  lastFourAccountNumber
        string
      
    
    
      
      
    
    
      required
    
    
    
  routingNumber
        string
      
    
    
      
      
    
    
      required
    
    
    
  status
        string<enum>
      
    
    
      
      
    
    
      required
    
    
    
  new,
    
      verified,
    
      verificationFailed,
    
      pending,
    
      errored
    
  updatedOn
        string<date-time>
      
    
    
      
      
    
    
      required
    
    
    
  exceptionDetails
        object
      
    
    
      
      
    
    
    
    
  errored or verificationFailed bank account status.
    Show child attributes
achReturnCode
        string<enum>
      
    
    
      
      
    
    
      required
    
    
    
  The return code of an ACH transaction that caused the bank account status to change.
- R02: Account Closed
 - R03: No Account/Unable to Locate Account
 - R04: Invalid Account Number
 - R05: Improper Debit to Consumer Account
 - R07: Authorization Revoked by Customer
 - R08: Payment Stopped
 - R10: Customer Advises Originator is Not Known or Authorized to Receiver
 - R11: Customer Advises Entry Not in Accordance with the Terms of the Authorization
 - R12: Branch Sold to Another DFI
 - R13: RDFI not qualified to participate
 - R14: Representative payee deceased or unable to continue in that capacity
 - R15: Beneficiary or bank account holder
 - R16: Bank account frozen
 - R17: Entry with Invalid Account Number Initiated Under Questionable Circumstances
 - R20: Non-payment bank account
 - R23: Credit entry refused by receiver
 - R29: Corporate customer advises not authorized
 - R34: Limited participation RDFI
 - R38: Stop Payment on Source Document (Adjustment Entry)
 - R39: Improper Source Document
 
R02,
    
      R03,
    
      R04,
    
      R05,
    
      R07,
    
      R08,
    
      R10,
    
      R11,
    
      R12,
    
      R13,
    
      R14,
    
      R15,
    
      R16,
    
      R17,
    
      R20,
    
      R23,
    
      R29,
    
      R34,
    
      R38,
    
      R39
    
  description
        string
      
    
    
      
      
    
    
      required
    
    
    
  errored or verificationFailed bank account status.
    rtpRejectionCode
        string<enum>
      
    
    
      
      
    
    
      required
    
    
    
  The rejection code of an RTP transaction that caused the bank account status to change.
- AC03: Account Invalid
 - AC04: Account Closed
 - AC06: Account Blocked
 - AC14: Creditor Account Type Invalid
 - AG01: Transactions Forbidden On Account
 - AG03: Transaction Type Not Supported
 - MD07: Customer Deceased
 
AC03,
    
      AC04,
    
      AC06,
    
      AC14,
    
      AG01,
    
      AG03,
    
      MD07
    
  paymentMethods
        array
      
    
    
      
      
    
    
    
    
  Includes any payment methods generated for a newly created bank account, removing the need to call the List Payment Methods endpoint following a successful Create BankAccount request.
NOTE: This field is only populated for Create BankAccount requests made with the X-Wait-For header.
Show child attributes
paymentMethodID
        string<uuid>
      
    
    
      
      
    
    
    
    
  paymentMethodType
        string<enum>
      
    
    
      
      
    
    
    
    
  moov-wallet,
    
      ach-debit-fund,
    
      ach-debit-collect,
    
      ach-credit-standard,
    
      ach-credit-same-day,
    
      rtp-credit,
    
      card-payment,
    
      push-to-card,
    
      pull-from-card,
    
      apple-pay,
    
      card-present-payment
    
  statusReason
        string<enum>
      
    
    
      
      
    
    
    
    
  bank-account-created,
    
      verification-initiated,
    
      micro-deposit-attempts-exceeded,
    
      micro-deposit-expired,
    
      max-verification-failures,
    
      verification-attempts-exceeded,
    
      verification-expired,
    
      verification-successful,
    
      ach-debit-return,
    
      ach-credit-return,
    
      rtp-credit-failure,
    
      micro-deposit-return,
    
      admin-action,
    
      other