Saferpay
The Saferpay integration supports several payment methods through Saferpay by Worldline (formally SIX Saferpay), including methods like TWINT particularly for the Swiss market.
Multi-merchant | Multi-currency |
---|---|
Payment Method | One-time | Recurring | Refunds |
---|---|---|---|
Card | |||
PostFinance Card | |||
PostFinance E-finance | |||
TWINT | |||
Bitcoin | |||
Ethereum | |||
Apple Pay | |||
Google Pay |
To fully enable E-Finance, PostCard or TWINT methods in your Saferpay test environment, you may need to contact Saferpay support. TWINT recurring payments, for instance, requires a business contract with Secure Alias Storage and TwintMerchantInitiatedPayment (User On File)
enabled on your terminal.
Pre-requisites
- FinDock installed and configured
- A successful connection to WebHub
Install and activate Saferpay extension
Follow the standard procedure for installing and activating the Saferpay payment extension.
Check and assign the required permissions. If you are using custom permission set groups, ensure the package-specific permission sets are assigned.
Configure Saferpay
Configuring the Saferpay extension requires setting up a test account with the Saferpay Backoffice and a production account with Saferpay myPortal. Some information from your Saferpay settings needs to be copied to the Saferpay for FinDock extension settings, so you will need to have both applications open to complete the configuration.
To configure Saferpay for FinDock:
- Got to the Remote Site Settings tab and activate one of the Saferpay endpoints.
- SaferpayProductionEndpoint: activate this endpoint if you are configuring a production org.
- SaferpayTestEndpoint: activate this endpoint if you are configuring a sandbox org for testing.
- Click the FinDock Setup tab to go back to the home page and then click on the Saferpay tile under the section Extensions - PSP.
- For the Notification URL, this value is automatically filled by the Notification Gateway.
- Register or log in to the Saferpay Backoffice at
https://test.saferpay.com/BO/
. If you are configuring a production org, use the Saferpay myPortal:https://myportal.six-payment-services.com/merchantportal/
- Take note of your 10-character username. This auto-generated username needs to be added to the Saferpay settings in FinDock.
- Click the Settings tab and then click JSON API basic authentication.
- When you created your back office account, you received an email from Saferpay with an JSON API username and password. If you no longer have this email, click Create new JSON API login to get a new login username and password.
- Copy-paste your JSON API login username and password into the corresponding fields in the Saferpay extension settings.
- On the Settings tab, click Payment Means / Terminals.
- Copy-paste your Customer ID and eCommerce Terminal ID into the corresponding fields in the Saferpay extension settings.
- On the Saferpay extensions settings page, adjust the extension options as needed, and the click Save.
- Use Secure Alias Storage: if your Saferpay contract includes the Secure Card Data module, enable this setting to use credit card aliases. NOTE: This setting is required when using TWINT recurring payments.
- Log Requests: activate if you want to log all Saferpay connection events.
- isTest: activate if you are configuring a sandbox org for testing.
Special handling for one-time vs. recurring
With Saferpay payment methods that support recurring payments, you use payment schedules to collect future installments of the recurring payment as normal.
In addition, for one-time payments made with the PostFinance PostCard method, you also need to run a payment schedule to collect the one-time payment.
Although the PostCard payment flow itself is similar to a normal credit card, the payment is made via direct debit. This requires its own set of instructions that FinDock sends the Saferpay API using the payment schedule process.
To enable recurring payment collection with TWINT, you need to have TwintMerchantInitiatedPayment (User On File)
enabled on your terminal and a Saferpay Business contract with Secure Alias Storage. Please contact Saferpay support for assistence.
To collect TWINT recurring payments, FinDock creates a payment profile with the following details. No more details are provided by Saferpay & TWINT to FinDock:
- Brand = TWINT
- Wallet Type = TWINT
- Record Type = Credit Card
No payment profile is created for one-time payments with TWINT, since no relevant data is provided and no payment profile & mandate combination is needed for future collection.
Payment profile deduplication is based on a combination of the Contact Id and Wallet Type, (i.e. only one TWINT wallet for each contact).
Special considerations for mandate references
To support Saferpay Secure Card Data capabilities, the Mandate object uses an Is Alias checkbox field. FinDock uses the checkbox to determine if the reference is an alias or a regular reference. By default, Is Alias is checked (true) for new recurring credit card payments.
The FinDock integration to Saferpay includes RegisterAlias
in all initial recurring payment callouts. This stores the alias on the Saferpay side. In FinDock, the alias on stored on the mandate reference field.
When you run a payment schedule, FinDock handles the callouts as required for both regular and alias references based on the Is Alias field.
If you are migrating recurring credit card payments to Saferpay from another PSP, you must set Is Alias to true to be able to process further installments through Saferpay.
Special considerations for cryptocurrency
When initiating cryptocurrency payments, the amount must use Swiss Franks (CHF) for the currency. FinDock automatically validates the currency and throws and API exception error if the ISO currency code is not CHF
.
For further information, please refer to the Saferpay Documentation about cryptocurrency requirements.
Special considerations for Apple Pay and Google Pay
These digital wallet methods are treated as card payments by Saferpay. Please refer to their documentation for Apple Pay and Google Pay for details on how these payments are processed. These options need to be enabled in your Saferpay back office account, but no additional configuration is needed in the FinDock extensions (no separate payment methods to enable).
The payment profile associated with Apple Pay or Google Pay uses the credit card record type. The Wallet Type field indicates which digital wallet is used.
For recurring payments with Apply Pay or Google Pay, you collect future installments using payment schedules. These installments are automatically included in payment schedules with PaymentHub-Saferpay as the payment processor and CreditCard as the payment method.
Payment API messages
You can use the following example messages to test if the Saferpay configuration is working as expected.
One-time payment with credit card
{
"SuccessURL": "https://www.example.com/success",
"FailureURL": "https://www.example.com/error",
"Payer": {
"Contact": {
"SalesforceFields": {
"FirstName": "Eric",
"LastName": "Johnson",
"Email": "eric@johnson.com"
}
}
},
"OneTime": {
"Amount": "30"
},
"PaymentMethod": {
"Name": "Creditcard",
"Processor": "Six-saferpay-for-findock"
},
"Settings": {
"SourceConnector": "PaymentHub"
}
}
Recurring payment with PostFinance card
{
"SuccessURL": "https://www.example.com/success",
"FailureURL": "https://www.example.com/error",
"Payer": {
"Contact": {
"SalesforceFields": {
"FirstName": "Eric",
"LastName": "Johnson",
"Email": "eric@johnson.com"
}
}
},
"Recurring": {
"Amount": "25",
"Frequency": "Monthly",
"StartDate": "2020-11-01"
},
"PaymentMethod": {
"Name": "PF PostCard",
"Processor": "Six-saferpay-for-findock"
},
"Settings": {
"SourceConnector": "PaymentHub"
}
}
One-time payment with PostFinance E-finance
{
"SuccessURL": "https://www.example.com/success",
"FailureURL": "https://www.example.com/error",
"Payer": {
"Contact": {
"SalesforceFields": {
"FirstName": "Eric",
"LastName": "Johnson",
"Email": "eric@johnson.com"
}
}
},
"OneTime": {
"Amount": "30"
},
"PaymentMethod": {
"Name": "PF e-finance",
"Processor": "Six-saferpay-for-findock"
},
"Settings": {
"SourceConnector": "PaymentHub"
}
}