GoCardless

Overview

↑ Back to top

The GoCardless extension provides the integration between WooCommerce and the UK-based, direct-debit GoCardless payment gateway, so store owners may collect online payments.

Bank Payments only appears as a payment method if the customer’s billing country is in:

  • Australia (AU)
  • New Zealand (NZ)
  • United States (US)
  • Canada (CA)

or on the list of SEPA countries:

  • Austria (AT), Belgium (BE), Bulgaria (BG), Switzerland (CH), Cyprus (CY), Czech Republic (CZ), Denmark (DK), Estonia (EE), Finland (FI), France (FR), Germany (DE), United Kingdom (GB), Greece (GR, Croatia (HR), Hungary (HU), Ireland (IE), Iceland (IS), Italy (IT), Liechtenstein (LI), Latvia (LV), Lithuania (LT), Luxembourg (LU), Malta (MT), Monaco (MC), Netherlands (NL), Norway (NO), Poland (PL), Portugal (PT), Romania (RO), Sweden (SE), San Marino (SM), Slovakia (SK), Slovenia (SI), Spain (ES).

While GoCardless can collect from customers in the above countries, note that GoCardless can only on-board merchants from:

  • Austria
  • Australia
  • Belgium
  • Denmark
  • Finland
  • France
  • Germany
  • Ireland
  • Luxembourg
  • Netherlands
  • Spain
  • Sweden
  • United Kingdom
  • United States
  • Canada

Requirements

↑ Back to top
  • GoCardless account
  • SSL Certificate with https:// included in path, e.g., https://example.com/wc-api/WC_Gateway_GoCardless/
  • WooCommerce version 8.4 or higher
  • WordPress version 6.1 or higher
  • PHP version 7.2 or higher

Installation

↑ Back to top
  1. Download the .zip file from your WooCommerce account.
  2. Go to: WordPress Admin > Plugins > Add New and Upload Plugin with the file you downloaded with Choose File.
  3. Install Now and Activate the extension.

More information at: Install and Activate Plugins/Extensions.

Register or sign in at GoCardless

↑ Back to top
gocardless-signup

To use GoCardless, you need an existing or new merchant account. To sign up for a new (free) account:

  1. Go to: gocardless.com
  2. Select Sign Up Now.
  3. Complete all fields (required).
  4. Select Create Your Account.

You can also sign up for GoCardless from the plugin settings. However, if you go this route, the instructions will be slightly different than described below in Setup and Configuration.

Setup and Configuration

↑ Back to top

There are two parts to setting up GoCardless on your WooCommerce Store: Connecting your GoCardless account and configuring GoCardless settings in your WooCommerce store.

Connect your GoCardless account

↑ Back to top

After installing the GoCardless gateway plugin, the first step is to connect your GoCardless account. Here’s how to connect it: 

  1. Go to WooCommerce > Settings > Payments.
  2. Click the toggle under Enabled to activate Bank pay (open banking and direct debit via GoCardless).
  3. Select Finish set up. You are taken to Bank pay (open banking and direct debit via GoCardless) settings.
  4. Select Connect with GoCardless.
  5. Log in to your GoCardless account. If you haven’t yet created an account, select Sign Up.
  6. If successful, an authentication notice will appear.
  7. Select the That’s My Site – Redirect Me button.
    That's my site
  8. Skip down to GoCardless Sync.
  9. Click the Dashboard link. A new window opens at GoCardless.
  10. Enter info in the Create Webhook Endpoint screen.
    • Name: Copy the Name from the GoCardless Sync section and paste it.
    • URL: Copy the URL from the GoCardless Sync section and paste it.
    • Secret: Copy the Secret from the GoCardless Sync section and paste it.
    • Webhook client certificate: Can be deselected
  11.  Select the Create Webhook Endpoint button.
  12.  Close the GoCardless webhooks endpoints window.
  13.  Return to the Bank pay (open banking and direct debit via GoCardless) settings screen at your store.
  14.  Save changes.

Stay on this screen for next steps.

Configuring Direct Debit (GoCardless) settings

↑ Back to top

Once you’ve connected your GoCardless account and WooCommerce store, to finish setting up your payment gateway configure the following settings:

  • Enable/Disable – Turn on or turn off.
  • Title – Enter a name displayed in checkout. Default is “Pay by bank”.
  • Description – Enter what the user sees in the checkout. Default is: “Pay securely via your bank account.”
  • Direct Debit Scheme – Select a scheme. Default is: Automatically detected from the customer’s bank account
  • Instant Bank Pay – Enable Instant Bank Pay to collect payments instantly using open banking wherever it is supported. By default, this feature is disabled and needs to be enabled to be used.
  • Log debug messages – Enabled and useful for troubleshooting purposes, if/when issues arise.
  • Save changes.

Test Mode – Sandbox

↑ Back to top

If you want to test the GoCardless gateway in sandbox before going live, this section describes the steps you need to take to enable sandbox mode.

  1. Disconnect from GoCardless if you are connected. If you are already disconnected, go to step 2.
  2. Select the “Not ready to accept live payments?” link.
  3. Repeat the above setup and configuration for setting up a live environment for the test environment.
  4. Test transactions using GoCardless test credentials.
    • In the UK, use the sort code 200000 and the account number 55779911
    • In Sweden, use the clearingnummer (branch code) 5527 and the kontonummer (account number) 1234512
    • Everywhere else, use the IBAN GB60 BARC 2000 0055 7799 11

When you are ready to go live, use the following steps:

  1. Use your live credentials and not the test credentials
  2. Connect to GoCardless
  3. Enable Direct Debit (GoCardless) on your WooCommerce site

Usage – Checkout flow

↑ Back to top

When checking out with GoCardless active, customers see an option for GoCardless which allows them to pay via Direct Debit or Instant Bank Pay (if enabled). There is also an option to save payment information. This section describes the customer checkout experience using these options and the steps they follow to complete their orders.

The GoCardless Payment Gateway supports collecting payments using the following methods:

  • Instant Bank Pay: Enables collection of payment on the spot with instant confirmation. Available for UK (GBP), Germany (EURO), and France (EURO) payments for now, with more schemes coming soon (see more details). By default, Instant Bank Pay is disabled, and payments are collected using Direct Debit setup. You can enable it from the GoCardless settings in your WooCommerce store.
  • Direct Debit: Collects customers’ bank details and authorization for the collection of future payments by Direct Debit.

When the customer tries to complete the order, a GoCardless JavaScript Drop-in will open to collect payment. This creates a mandate (a direct debit authorization from the customer to collect future payments) and then collects payment for the order.

Customers may also choose to securely save payment information so they need not re-enter for future transactions. Instead, they would select an option:

Once the customer completes the steps in the Drop-in, the order will be placed, and the standard WooCommerce order confirmation will be shown:

Opening the order screen, you see all the details. GoCardless gives the status of those transactions via the webhook.

Note that direct debit payments don’t process instantly and work differently than card payments. More info at: How Direct Timings Work.

Troubleshooting

↑ Back to top

GoCardless payment statuses

↑ Back to top

Every GoCardless Direct Debit payment goes through certain statuses before it is paid out to the merchant. This section describes how to find out the status of a payment and what the status means.

You can read more about each status on the GoCardless Payment statuses documentation.

These stages are displayed in two places:

  • At the top of the payment details section within the GoCardless dashboard when viewing individual payments
    On the WooCommerce Edit Order Page under “GoCardless Webhook Events”
GoCardless Payments Overview Page
GoCardless Individual Payment page

WooCommerce interface

WooCommerce edit order page

Payment flow for WooCommerce order through GoCardless

↑ Back to top

When your customer places an order, GoCardless creates a mandate. This mandate gives you permission to collect payments from your customer’s bank account. The WooCommerce order will be initially put On Hold until the payment is confirmed by GoCardless. Once the payment is confirmed, the order will be updated to Processing or Completed based on the type of product.

While the order is On Hold, the GoCardless payment will have a pending submission status. After submission, your customer’s bank must approve the payment. This process takes between 2-7 days. Once the bank confirms the payment, we’ll update your order status automatically.

Example of GoCardless webhook events
Example of corresponding WooCommerce order notes

Subscriptions paid via GoCardless

↑ Back to top

Subscriptions orders paid via GoCardless have a different flow than regular WooCommerce orders.

When a subscription is paid via GoCardless, the order is directly set to Processing regardless of whether the payment has been confirmed yet or not. The order and subscription status will update automatically when your customer’s bank confirms the payment status.

Example of Subscriptions order flow:

  • Subscription Order is placed -> Parent order is set to Processing although payment is not taken yet -> Subscription status is set to Active
  • After a few days, the bank confirms the payment -> Subscription will stay Active
  • If the bank rejects the payments and it fails -> Order status will be updated to Failed -> Subscription will be put On Hold

This same flow applies to Subscriptions renewal orders.

Subscriptions parent order notes

Testing GoCardless transactions: using the sandbox

↑ Back to top

You can use the sandbox to test your GoCardless setup.

Create a sandbox account: As a first step, create a GoCardless sandbox account to test transactions. Please see the instructions above under configuring GoCardless. You can also create a sandbox account directly.

Find test bank details:

Testing flow:

  • Place an order on your site via GoCardless. The WooCommerce order will be put on On Hold (assuming a regular, non-Subscription product)
  • Go to the Edit Order Page and note the payment ID of the transaction
Note the GoCradless payment ID on the WooCommerce order page
  • Go to GoCardless Dashboard and find the payment with pending_submission status
GoCardless Dashboard
GoCardless Dashboard: Simulate a scenario
  • Next we will simulate the payment for the order. Before we simulate the payment, we will need to activate the mandate for this payment. To do so, we will need the the mandate ID. You can obtain the mandate ID by going to the individual payment in the GoCardless dashboard and selecting mandate from there:
Animated gif showing how to access mandate for a given payment.
GoCardless dashboard: Mandate of a payment
  • Copy the Mandate ID then “Activate” the mandate by Simulating a Scenario
Screenshot from Simulate a scenario modal in GoCardless.
The scenario can be chosen from the scenario dropdown. In this example the selected scenario is Mandate activated.
The description fields explains that the action transitions a mandate through to activated, having been
submitted to the banks and set up successfully.
We also see the Mandate ID.
GoCardless dashboard: activate a mandate
  • Now you can update the payment status as required by simulating another scenario
Screenshot from Simulate a scenario modal in GoCardless.
The Payment confirmed scenario is selected within the Scenario dropdown. The description fields explains that this action transitions a payment through to 'confirmed'. It must start
in the pending_submission state, and its mandate must
be in the activated state (unless it is a payment for ACH,
BECS, BECS_NZ or SEPA, in which cases the mandate may
be pending_submission, since their mandates are
submitted with their first payment).
Payment ID is also displayed.
Gocardless dashboard: Updating payment status
  • Now both the GoCardless payment status and the WooCommerce order status will be updated. You can view the details in the GoCardless Dashboard as well as in the Edit Order Page
Screenshot from GoCardless order with Confirmed status.
GoCardless Dashboard: updated payment status
Screenshot from the WooCommerce order showing order status as Processision and listing GoCardless Webhook events as payments confirmed followed by payments created.
WooCommerce order: updated payment and order status

To learn more about simulating scenarios and testing GoCardless transactions, please refer to the GoCardless Scenario Simulator Tools documentation.

Frequently Asked Questions

↑ Back to top

Does GoCardless support BACS?

↑ Back to top

Yes, the GoCardless extension supports BACS and the payment methods mentioned in the GoCardless API documentation.

I’m based in country x – can I use GoCardless on my site?

↑ Back to top

While GoCardless can collect from customers from many countries, note that GoCardless can only on-board merchants from Austria, Belgium, Finland, France, Germany, Ireland, Luxembourg, Netherlands, Spain, Sweden, United Kingdom, United States, and Canada.

Do I need to fill in the webhook secret?

↑ Back to top

Yes, you need to manually fill in the webhook secret and configure the webhook endpoint. We’ve made it as easy as possible.

How are payment methods selected?

↑ Back to top

The system automatically chooses between Instant Bank payments and Direct Debit based on:

  1. Whether both you and your customer support Instant Bank payments
  2. The type of products being purchased

For example, the system uses Instant Bank Pay for single product purchases when the customer’s billing address is in:

  • UK (GBP)
  • Germany (EUR)
  • France (EUR)

For subscription products in these same regions, the system uses both Instant Bank Pay and Direct Debit (mandate).

For regions that don’t support instant payments, the system only uses Direct Debit (mandate).

Why does the GoCardless gateway classify all transactions as “recurrent”?

↑ Back to top

GoCardless processes most payments through Direct Debit mandates, even for one-time purchases. This mandate allows for future payment collection, which is why transactions appear as “recurrent” in your dashboard.

Exception: For merchants and customers in the UK (GBP), Germany (EUR), and France (EUR), GoCardless offers Instant Bank Pay (IBP). These payments process immediately without a Direct Debit mandate and don’t show as recurrent.

Why are my orders not redirecting to the thank you page or marked as paid?

↑ Back to top

If you use a security or firewall plugin or have a firewall application on your server, be sure that you allow requests from GoCardless in that plugin’s settings. GoCardless sends webhooks from the following IP addresses which you may wish to add to your firewall’s approved list:

  • 35.204.73.47
  • 35.204.191.250
  • 35.204.214.181

Why Haven’t I Received My GoCardless Payouts?

↑ Back to top

Before GoCardless sends your payouts, you must complete account verification. Check your email inbox and spam folder for verification instructions from GoCardless. GoCardless will also email you when your funds are ready for payout.

Does GoCardless support tokenization?

↑ Back to top

Yes. As described in the Usage section, customers may opt to securely store payment information for future checkout.

Can I use GoCardless with pre-orders?

↑ Back to top

GoCardless includes support for WooCommerce Pre-Orders (separate purchase).

Can I use GoCardless with subscriptions?

↑ Back to top

Yes, it’s possible to use GoCardless to accept automatic, recurring payments for WooCommerce Subscriptions (separate purchase).

Do I need to Create an App?

↑ Back to top

Merchants need only click the Connect button to hook up their GoCardless account. It’s not necessary to Create an App.

Create an App is for developers seeking to code their own applications from scratch and not use the GoCardless for WooCommerce extension or any other already made.

Does this work with Pro and Plus packages?

↑ Back to top

Yes. As of version 2.4.5, WooCommerce GoCardless includes support for merchants upgrading to Pro and/or Plus. It:

  • Notifies via webhook with event “mandate_replaced” with the new mandate in the payload.
  • Gives an error response about mandate replacement when payment is created with the old mandate.

Code customization

↑ Back to top

Hooks

↑ Back to top
woocommerce_gocardless_after_billing_request_fulfilled - do_action( 'woocommerce_gocardless_after_billing_request_fulfilled', $billing_request );

This action hook can be used to further manipulate information after a billing request is fulfilled. One such example would be to update the customer information on the GoCardless side.  Here’s how the snippet can be formatted to achieve that:

add_action( 'woocommerce_gocardless_after_billing_request_fulfilled', 'process_billing_request' );

function process_billing_request( $billing_request ) {
    $customer_id = wc_clean( $billing_request['links']['customer'] );
    $data        = array(); // Add customer data here
    WC_GoCardless_API::update_customer( $customer_id, $data );
}

Filters

↑ Back to top

Now, there are three filters for updating initial order status:

  • woocommerce_gocardless_create_payment_subscription_order_status — default to processing. Triggered when an order contains a Subscription product
  • woocommerce_gocardless_create_payment_subscription_renewal_order_status — default to processing. Triggered when an order contains a Subscription renewal
  • woocommerce_gocardless_create_payment_order_status — default to on-hold

Questions and Support

↑ Back to top

Something missing from this documentation? Do you still have questions and need assistance?

  • Have a question about a specific extension or theme you’d like to purchase? Click here.
  • Already purchased and need some assistance? Get in touch with a Happiness Engineer via the qphmycoi.top Support page and choose this extension name from the “I need help with” dropdown.

Use of your personal data
We and our partners process your personal data (such as browsing data, IP Addresses, cookie information, and other unique identifiers) based on your consent and/or our legitimate interest to optimize our website, marketing activities, and your user experience.