1. Documentation /
  2. Paysafe Payment Gateway /
  3. Paysafe Checkout JS API Integration

Paysafe Checkout JS API Integration

Paysafe Checkout API uses a secure JavaScript-based overlay to allow merchants to collect payments via credit cards and direct debit. The sensitive payment information is only handled by Paysafe and never reaches the merchant store lowering the PCI compliance level for the payments to the least demanding SAQ-A.
The gateway supports the following payment processes:
  1. Sale and Authorization Only payments
  2. WooCommerce Subscriptions product payments (requires separate plugin “WooCommerce Subscriptions“)
    1. Important: WooCommerce Subscriptions version 2.0 and higher are supported only
  3. WooCommerce Pre-Orders product payments (requires separate plugin “WooCommerce Pre-Orders“)
  4. Process refunds directly from the Edit Order screen.
  5. Capture payments directly from the Edit Order screen.
  6. Pay with tokens. Payment tokenization

Prerequisites

↑ Back to top
  1. WooCommerce version 3.0 or higher
  2. For WooCommerce Subscriptions, version 2.0 or higher
  3. PHP version 5.3 or higher

Installation

↑ Back to top
  1. Download the .zip file from your WooCommerce account.
  2. Go toWordPress 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.

Quick Setup and Configuration

↑ Back to top
Here is how you can set up your Paysafe integration within just a few steps. All required fields have a red asterisk next to them.
  1. Login to your WooCommerce store.
  2. Go to: WooCommerce > Settings > Payments > Paysafe Checkout API.
  3. Enter Method Title and Method Description
  4. Under the Credentials Settings, enter your API Keys.
  5. Under Merchant Accounts Settings, enter at least the Cards Account ID
  6. Leave everything else as default.
  7. Start accepting payments
Recommended: make a few test payments before you go live. In live mode make a couple of small live test payments, too.

Setting Options

↑ Back to top
We can break down the settings into sections. Every section controls part of the integration.

Integration Type Settings

↑ Back to top
This section is used to choose from the integration types the plugin offers. Currently, we offer two integration types and if you are reading the Checkout API documentation page, then you probably already chose the Checkout API integration type. Here is a breakdown of how an integration type selection works:
  1. You choose one of the options from the Integration Type selection setting
  2. After you change your selection you will see a notice under it prompting you to save the change before you continue.
  3. When you click the “Save changes” button, the page will refresh and you will be ready to set up your gateway.

General Settings

↑ Back to top
  • Method Title:
    • This controls the title which the user sees during checkout. Also, it is displayed whenever the gateway is referenced.
  • Description:
    • This controls the description which the user sees during checkout.

Credentials Settings

↑ Back to top
In this section you will enter your API credentials, so we can connect to the Paysafe gateway. The API Key credentials are used to make backend requests to the Paysafe servers. The Single-Use Token credentials are used to load and display the payment overlay.
Note: Below in the section “How to find my Credentials” you can see how to find your credentials in the Paysafe Dashboard.
  • API Key: User Name:
    • This is the API Key User Name found in your Paysafe Dashboard > Settings > API Key.
  • API Key: Password:
    • This is the API Key Password found in your Paysafe Dashboard > Settings > API Key.
    • Note: The Password will not appear in the text field, but a placeholder will let you know if it is set or not.
  • Single-Use: User Name:
    • The User Name from the section ‘Single-Use Token’ in the Paysafe account settings
  • Single-Use: Password:
    • The corresponding password to the ‘Single-Use Token’ User Name.
    • Note: The Password will not appear in the text field, but a placeholder will let you know if it is set or not.

Merchant Accounts Settings

↑ Back to top
  • Card Account IDs: The IDs are required to process a card payment. Please enter at least one Account ID.
    • Please enter one Account ID per store currency.
    • Multi-currency stores can set an Account ID for each currency they supportWooCommerce Paysafe
  • 3D Secure: If your merchant account is enabled for 3D Secure payment authentication, you can enable the authentication here.
  • PDS2(3DS2) Support: Enable 3DS2 for card transactions.
  • CVV Card Field: When enabled, the CVV field will appear and be required for payments with saved cards
  • Direct Debit Account IDs: The Account IDs here are used to process direct debit transactions. Leave empty, if you are not accepting direct debit payments

Transaction Settings

↑ Back to top

  • Payment Pages Language:
    • Controls the language of the Paysafe payment page. You can choose from 4 languages US English and French Canadian.
  • Authorization Type:
    • Sale“, will capture the fund together with the transaction authorization.
    • Authorization Only“, will only perform authorization and let you capture the funds at a later date.
  • Accepted Cards
    • This setting will allow you to easily display your accepted payment methods on the checkout page payment option. It will not control the actual payment cards accepted on the Paysafe payment page, it is just an easy way to show the correct card icons on the checkout page.

Vault Settings

↑ Back to top
The settings in the vault section will allow you to allow your customer to tokenize their payment methods, save them on the Paysafe secure servers and pay with them for future orders.
  • Saved Cards:
    • Enables the vault functionality. When enabled the plugin will display a checkbox to the customer asking for permission to save their card for future payments.
  • Vault Profile Prefix:
    • For merchants with multiple stores, the prefix is used for the gateway to differentiate between your stores. Enter something meaningful to you or just leave it as default value.
  • Save Card Checkbox Default State:
    • Controls the state of the checkbox asking the customer to save their information for future payments. As checked or unchecked.
  • Save Your Payment Method Text:
    • The text to prompt the user to save their payment method for future payments. Default is “Save to Account”, but you can enter anything here letting the customer know what will happen

Layover Settings

↑ Back to top
The layover settings are the settings that customize the payment layover. You can customize logos, colors and company name
  • Layover Image:(1)
    • (Optional)This is the logo image displayed on top of the layover. The recommended size of the image is 56px by 56px, but you can also try larger or smaller images cropped to a 1:1 ratio.
    • Enter the URL path to the image as you would access it on your website. Example: https://yoursite.com/wp-content/uploads/2013/09/yourimage.jpg
    • Note: It is required that the image is secured with “https://“. Entering an “http://” image will result is a layover load error.
  • Merchant Name:(2)
    • (Optional) Enter there a merchant name you want to display under the layover image(2). The name should be up to 60 characters.
  • Button Color:(4)
    • This is the Pay button color. You should enter the colors in Hex Code RGB, such as #ffffff for white or #000000 for black. There are a number of web colorpickers to help you with the value of your color.
  • Default Payment Method:(3)
    • Pick which method should be selected by default when the Layover is displayed. For example, is you have Cards and DirectDebit payments, you can choose to display DirectDebit as selected by default, this way urging your customers to pay by this method.

Test and Debug Settings

↑ Back to top
  • Enable Debug mode
    • Debug logs the plugin processes for easier troubleshooting.
    • You can see here the location of the generation debug log or you can get the log by going to WooCommerce > Status > Logs > pick the log you want and click View.

Process Refunds

↑ Back to top
It is very simple to process a refund through the plugin. Here is the quick rundown:
Note: For more information on how refunds work please visit the WooCommerce Refunds documentation.

Refund steps

↑ Back to top
  1. Go to the “Order Edit” screen
  2. Under “Items” meta box, in the bottom left corner, you will see a “Refund” button. Click it.
  3. Entering the refund amount can be a bit confusing. What you have to remember here is that you are refunding an amount from each order item or fee(step 1 in the image below) and not from the order as a whole. This is done so that taxes are refunded appropriately from the item as well. The field “Refund amount” will be automatically populated and you will not be able to enter an amount in it.
  4. Enter a reason for the refund or a note to remember why was the refund processed (step 2 in the image above)
  5. Press the “Refund … via Paysafe” button (step 3 in the image in the image above)
  6. The refund will be processed and upon page refresh you will see an order note, noting the refund amount, reason and transaction ID.

Refund a Direct Debit transaction

↑ Back to top
The Direct Debit transaction does not support a transaction refund in a sense that the settlement is canceled and the amount is returned to where they came from. Instead, using the Direct Debit transaction, the merchant is transferring money to the customer bank account as a separate bank transfer. For this reason, the customer bank account details will be displayed above the refund button for the merchant to review before refunding the transaction.
Important: Do not refund Direct Debit transactions unless you can review the account you are transferring money to.

Capture Payments

↑ Back to top
To capture previously authorized payments all you need to do is follow the steps:
Note: Only a single capture is possible per transaction. You can capture up to the initially authorized amount, no matter what the current order total is.
  1. Go to the “Order Edit” screen
  2. Under “Items” meta box, in the bottom left corner, you will see a “Capture” button. Click it to expose the capture input fields.
  3. Enter the amount you want to capture from the order.
    Note: You will see how much is authorized, you can’t capture more than that amount.
  4. Press Capture Payment button.
  5. A note will be left on the order with details about the captured amount and the transaction ID from the process.

How to find my Credentials

↑ Back to top
You can find your credentials by going to your in your Paysafe dashboard > Settings > API Keys:
  1. Under the API Keys section, you will find the API Key User name and Password.
  2. Under the Single-Use Token section, you will find the Single-Use User name and Password.
  3. Don’t use the Copy button to copy the API Password. It looks like you are copying the password, but it copies both the username and password in one string.

FAQ & Troubleshooting

↑ Back to top

We have a separate Merchant Account ID for each currency in my store. Can I use my other Account IDs depending on the order currency?

↑ Back to top
Use the Merchant Account Settings to set an Account ID for each currency you support.

We set the integration, but when we attempt to process a transaction, we receive an error 5279. What can we do to fix the issue?

↑ Back to top
It is very likely that you are processing 3D secure transactions when your merchant account is not enabled for 3D secure. In the Merchant Account Settings, please enable or disable the 3D Secure setting.

I want to open the Payment form automatically when the customer reaches the Pay page. How can I do that?

↑ Back to top
Use the code below to trigger the form submit event and open the payment form. Keep in mind that we did not add this by default because the customer has a “Save to account” choice that they need to act on before they open the payment form.
add_action( 'wp_footer', 'prefix_add_script_to_footer' );
/**
* Adds a script to automatically load the Paysafe Layover on the WooCommerce pay page
*/
function prefix_add_script_to_footer() {
if ( ! is_checkout_pay_page() ) {
return;
}
?>
<script>
/**
* This is JavaScript code and it should be added to any file that will load it on the WooCommerce "Pay" Page
*
* The code will automatically start the Payment form without requiring the customer to click on the Pay button.
* Important: Keep in mind that if you allow Tokenization, the customer will not be allowed to choose to save their card or not
*/
(function ($) {
$(document).ready(function () {
var isPayPage = $('body').hasClass('woocommerce-order-pay');
if (true === isPayPage) {
setTimeout(function () {
$('#paysafe_checkout_payment_form').submit();
}, 800);
}
});
})(jQuery);
</script>
<?php
}

Questions & Support

↑ Back to top
Have a question before you buy? Please fill out this pre-sales form. Already purchased and need some assistance? Get in touch the developer via the Help Desk.