Payment-method icon

ACH Direct Debit Component

Add ACH Direct Debit to an existing Components integration.

This page explains how to add ACH Direct Debit to your existing Web Components integration.

Requirements

Select the server-side flow that your integration uses:

Requirement Description
Integration type Make sure that you have built a Sessions flow Web Components integration.
Setup steps Before you begin, add ACH Direct Debit in your Customer Area.

Import resources for v6

If you are using Web Components v6, import the Component that you need for ACH Direct Debit:

Copy code
import { AdyenCheckout, Ach } from '@adyen/adyen-web'

API reference

Select which endpoint you are using:

This is the default with Web Components v5.0.0 or later.

Parameter name Required Description
billingAddress -white_check_mark- Only required for v6.3.0 and earlier.
The postal address of the shopper. Recommended to increase conversion rates.
Expand view
Copy link to code block
Copy code
Copy code
curl https://checkout-test.adyen.com/v69/sessions \
-H 'x-api-key: ADYEN_API_KEY' \
-H 'content-type: application/json' \
-d '{
"merchantAccount": "YOUR_MERCHANT_ACCOUNT",
"amount": {
"value": 1000,
"currency": "USD"
},
"returnUrl": "https://your-company.com/checkout?shopperOrder=12xy..",
"reference": "YOUR_ORDER_NUMBER",
"countryCode": "US",
"billingAddress":{
"city":"Amsterdam",
"country":"US",
"houseNumberOrName":"50",
"postalCode":"12010",
"stateOrProvince":"NY",
"street":"Test Street"
}
}'

Component configuration

Step 1: Create a DOM element

Create a DOM element on your checkout page, placing it where you want the payment method form to be rendered:

Copy code
 <div id="ach-container"></div>

Step 2: Create an instance of the Component

v6.0.0 or later

Create an instance of the Component, passing:

  • Your instance of AdyenCheckout.
Copy code
const achDirectDebit = new Ach(checkout).mount('#ach-container');

Use the create method of your AdyenCheckout instance, in this case checkout, to create the Component:

Copy code
const achDirectDebitComponent = checkout.create('ach').mount('#ach-container');

Optional configuration

When creating an instance of Components, you can optionally include the following parameters in the payment methods configuration object:

Field Description Default
billingAddressRequired Set to false to hide billing address fields if you want to pass the data yourself. true
enableStoreDetails
v5.24.0 or later
Set to true to show the checkbox for saving the payment details. false
hasHolderName Set to false to hide this field if you want to pass the data yourself. true
holderNameRequired Set to false if you want to make it optional for the shopper to fill cardholder name fields. true

Payment outcome

After we successfully received your request, it may take up to five business days to know whether the payment was authorised by the bank. If the bank authorised the payment, it will appear in the Settlement details report. If the bank failed to authorise the payment, you will receive a CHARGEBACK webhook.

Test and go live

You can test ACH Direct Debit payments as well as chargebacks.

Test the payment flow

Before making live ACH Direct Debit payments, use the following account details to test your integration.

ownerName bankAccountNumber bankLocationId
(routing number)
billingAddress
(account owner's address)
Any name Any correctly formatted account number.
Example: 1234567890
011000138 or 121000358 Any correctly formatted US address.

Test the chargeback flow

You can test the chargeback flow by making test payments with an ownerName value that consists of chargeback: followed by an ACH return reason code. For example, chargeback:R01. The other account details to use are the same as when testing payments.

For instructions, see Test a chargeback scenario.

See also