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:
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 | Only required for v6.3.0 and earlier. The postal address of the shopper. Recommended to increase conversion rates. |
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:
<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
.
const achDirectDebit = new Ach(checkout).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.