Payment brands, such as card schemes and debit network providers, charge a fee for accepting payments on their payment network, called a payment acceptance fee. As a platform, you must have agreements in place with your users about how the payment acceptance fee is charged for each payment.
Your users can pass on these costs to their customers by adding a surcharge to their payments.
Requirements
Before you begin, take into account the following requirements, limitations, and preparations.
Requirement | Description |
---|---|
Integration type | Make sure you have an existing Terminal API integration or an Android or iOS Tap to Pay integration. |
API credentials | You must have an API credential with an API key and the following roles:
If you have a Terminal API integration with cloud-based communications, you can use the existing API key that you use for Terminal API requests. |
Hardware | It is not possible to configure surcharges for card readers in a mobile integration. |
Limitations | Note the following:
|
Setup steps | Be aware that regulations require informing the customer that a surcharge is added to the payment amount. |
How it works
After the surcharge amounts and/or percentages are configured:
-
You make a payment request like you normally do. There are no special parameters required to trigger the surcharge.
-
The screen shows the purchase amount and instructs the customer to present their card.
-
Based on the card that the customer presents, the terminal calculates the surcharge using the surcharge amounts and/or percentages you configured.
-
If configured, the terminal shows a confirmation screen with the total amount of the payment, the surcharge amount, and the card scheme that the extra fee is charged for.
In a Tap to Pay integration, the mobile device doesn't show a confirmation screen. The surcharge is applied automatically.
-
On the terminal, the customer selects the Confirm key to accept, and the payment is processed. The payment response shows the surcharge amount in the
TotalFeesAmount
field.If the customer doesn't accept the surcharge and selects the Cancel key, the whole transaction is cancelled.
Skipping the confirmation screen
It takes a bit of time for the customer to review the confirmation screen with the surcharge details. To avoid this delay in the payment flow, you can configure a setting to hide this screen. For Tap to Pay transactions that include surcharges, the confirmations screen doesn't show.
Be aware that regulations require you to inform the customer that a surcharge is added to the payment amount.
The flow will then be:
- You make a payment request like you normally do.
- The customer completes the payment.
- Based on the card that the customer presents, the terminal calculates the surcharge and adds it to the payment amount during the authorization.
Configure surcharges
The payment acceptance fee charged to your user depends on the payment method brand (scheme), funding source (credit or debit), currency, and the country/region that issued the payment method (domestic or international). Therefore, the surcharge that your user passes on to the customer must be specific for the combination of brand, funding source, currency, and country/region.
The surcharge fee can be a fixed amount for each transaction, a percentage of the sum of the purchase amount and the tip, or both. You can configure the surcharge logic for payments based on the agreements you have with your users.
To configure surcharges:
-
Check the current surcharge configuration (if any) by making a GET request to the
/terminalSettings
endpoint for the company account, merchant account, store or terminal, and checking thesurcharge
object. -
Create an overview of all surcharges that you want to apply. For example:
Brand Funding source Country/region Currency Percentage Amount eftpos AUD (none) AUD 0.10 Mastercard Credit AUD 1.2 % AUD 1 Mastercard Debit AUD 0.58 % (none) Visa Credit or Debit AU, NZ AUD 0.63 % (none) Visa Credit or Debit AUD 1.63 % (none) American Express Credit AUD 1.5 % AUD 1.2 Specifying the
country
field inside theconfigurations
object applies the surcharge settings only to payment methods issued in that country/region. If not specified, the surcharge applies to all payment methods that meet the rest of the conditions. -
Make a PATCH request to the
/terminalSettings
endpoint for the company account, merchant account, store or terminal.
In the request body, specify a surcharge object with the following properties:Parameter Data type Description askConfirmation Boolean Indicates whether to show (true) or hide (false) the surcharge confirmation screen on the terminal. configurations Array[Object] List of payment methods for which to apply surcharges with the details per payment method. The order of different surcharge objects inside theconfigurations
array impacts the order of execution. The condition that is met first is executed without checking the rest of the configuration.In the configurations object, specify:
Parameter Required Description brand
A payment method supported for Management API, for example eftpos_australia
ormc
.currencies
An object with: currency code
: the three-character ISO currency code.percentage
: surcharge percentage per transaction up to two decimal places. For example, 1% or 2.27%.amount
: surcharge amount per transaction, in minor units.
sources
Can be: Credit or Debit. If not specified, the currencies
settings apply to all possible funding sources for thebrand
.country
The country/region where the specified payment method has been issued. If used, the surcharge settings only apply to the payment method issued in that country/region. Configure surchargesExpand viewCopy link to code blockCopy codecurl https://management-test.adyen.com/v3/stores/{storeId}/terminalSettings \ -H 'x-API-key: YOUR_X-API-KEY' \ -X PATCH \ -d '{ "surcharge":{ "askConfirmation":true, "configurations":[ { "brand":"mc", "sources":[ "Credit", "Debit" ], "currencies":[ { "currencyCode":"AUD", "percentage":"0.58", "amount":"100" } ] }, { "brand":"eftpos", "sources":[ "Debit" ], "currencies":[ { "currencyCode":"AUD", "amount":"10" } ] }, { "brand":"visa", "sources":[ "Credit" ], "currencies":[ { "currencyCode":"AUD", "percentage":"1.2" } ], "country":[ "AU", "NZ" ] }, { "brand":"visa", "sources":[ "Credit" ], "currencies":[ { "currencyCode":"AUD", "percentage":"2.2" } ] } ] } }' The response returns all terminal settings at the level where you made the request.
Terminal settings responseExpand viewCopy link to code blockCopy code{ "cardholderReceipt":{ "headerForAuthorizedReceipt":"header1,header2,filler" }, "gratuities":[ { "currency":"EUR", "usePredefinedTipEntries":true, "predefinedTipEntries":[ "100", "1%", "5%" ], "allowCustomAmount":true } ], "nexo":{ "displayUrls":{ "localUrls":[ { "password":"YOUR_PASSWORD", "url":"https://your-display-notifications-endpoint.com", "username":"USERNAME" } ] }, "encryptionKey":{ "identifier":"SHARED_KEY", "passphrase":"PASSPHRASE", "version":1 }, "eventUrls":{ "eventPublicUrls":[ { "password":"YOUR_PASSWORD", "url":"https://your-event-notifications-endpoint.com", "username":"USERNAME" } ] } }, "opi":{ "enablePayAtTable":true, "payAtTableStoreNumber":"1", "payAtTableURL":"https:/your-pay-at-table-endpoint.com" }, "offlineProcessing":{ "chipFloorLimit":0 }, "receiptOptions":{ "qrCodeData":"http://www.example.com/order/${pspreference}/${merchantreference}" }, "receiptPrinting":{ "shopperApproved":true, "shopperRefused":true, "shopperCancelled":true, "shopperRefundApproved":true, "shopperRefundRefused":true, "shopperVoid":true }, "signature":{ "askSignatureOnScreen":true, "skipSignature":false, "deviceName":"Amsterdam-236203386" }, "wifiProfiles":{ "profiles":[ { "authType":"wpa-psk", "autoWifi":false, "bssType":"infra", "channel":0, "defaultProfile":true, "hiddenSsid":false, "name":"Guest Wi-Fi", "psk":"4R8R2R3V456X", "ssid":"G470P37660D4G", "wsec":"ccmp" } ], "settings":{ "band":"All", "roaming":true } }, "timeouts":{ "fromActiveToSleep":30 }, "hardware":{ "displayMaximumBackLight":75 }, "passcodes":{ "adminMenuPin":"1234", "txMenuPin":"1234", "screenLockPin":"1234" }, "storeAndForward":{ "maxAmount":[ { "amount":10000, "currencyCode":"EUR" } ], "maxPayments":10, "supportedCardTypes":{ "credit":true, "debit":true, "deferredDebit":true, "prepaid":true, "unknown":false } }, "terminalInstructions":{ "adyenAppRestart":true }, "surcharge":{ "askConfirmation":true, "configurations":[ { "brand":"mc", "sources":[ "Credit", "Debit" ], "currencies":[ { "currencyCode":"AUD", "percentage":"0.58", "amount":"100" } ] }, { "brand":"eftpos", "sources":[ "Debit" ], "currencies":[ { "currencyCode":"AUD", "amount":"10" } ] }, { "brand":"visa", "sources":[ "Credit" ], "currencies":[ { "currencyCode":"AUD", "percentage":"1.2" } ], "country":[ "AU", "NZ" ] }, { "brand":"visa", "sources":[ "Credit" ], "currencies":[ { "currencyCode":"AUD", "percentage":"2.2" } ] } ] } } -
(Optional) Ask our Support Team to configure single tap. When this feature is enabled, the customer doesn't need to present their contactless card again after the terminal has calculated the total amount.
When accepting payments with surcharges using Tap to Pay on a mobile device, only single tap flow is available.
Book the surcharge to your user
A surcharge is a type of transaction fee imposed by the card scheme, paid by your user's customer. Similar to the other transaction fees, you can use split instructions to define how to book the surcharge.
By default, the surcharge amount on a payment is booked to your liable balance account. However, you can book this amount directly to your user's balance account.
- When splitting a payment, add a split item for the surcharge.
When adding a new split item, always include this in the total number of split items specified in the
split.nrOfItems
field. -
For the split item of the surcharge, specify:
Key Description Example split.item[ITEM_NUMBER].type
The type of split. Set this to Surcharge. split.item5.type=Surcharge split.item[ITEM_NUMBER].account
Account that will receive the surcharge. This is the balanceAccountID
of one of your user's balance accounts.You cannot split the surcharge between multiple balance accounts.split.item5.account=BA00000000000000000000001 split.item[ITEM_NUMBER].reference
Your reference for the surcharge, reflected in the Balance Platform Accounting Report. split.item5.reference=reference_surcharge split.item[ITEM_NUMBER].description
Your description for the surcharge, reflected in the Balance Platform Accounting Report. split.item5.description=description_surcharge You do not need to include the surcharge amount in the
split.totalAmount
orsplit.item[ITEM_NUMBER].amount
fields, since the surcharge amount is only calculated after the customer presents their card.
For example, a payment of EUR 636.00 is split into:
- EUR 600.00 to be booked to your user's first balance account as the sale amount.
- The payment fee to be booked to your user's first balance account. This will be deducted from the sale amount.
- EUR 10.00 to be booked to your user's first balance account as the tip.
- EUR 6.00 to be booked to your user's first balance account as the surcharge.
- EUR 20.00 to be booked to your liable account as your platform's commission.
In this case, set the split.nrOfItems
to 5 and split.totalAmount
to 62000 (the amounts for the tip, payment fee, and surcharge are not known when sending the payment request).
{ "SaleToPOIRequest": { "MessageHeader": { "ProtocolVersion": "3.0", "MessageClass": "Service", "MessageCategory": "Payment", "MessageType": "Request", "SaleID": "POSSystemID12345", "ServiceID": "0207111104", "POIID": "V400m-324688179" }, "PaymentRequest": { "SaleData": { "SaleTransactionID": { "TransactionID": "27908", "TimeStamp": "2022-10-28T10:11:04+00:00" }, "SaleToAcquirerData": "split.api=1&split.nrOfItems=5&split.totalAmount=62000&split.currencyCode=EUR&split.item1.amount=60000&split.item1.type=BalanceAccount&split.item1.account=BA00000000000000000000001&split.item1.reference=reference_split_1&split.item1.description=description_split_1&split.item2.amount=2000&split.item2.type=Commission&split.item2.reference=reference_commission&split.item2.description=description_commission&split.item3.type=Tip&split.item3.account=BA00000000000000000000001&split.item3.reference=reference_tip&split.item3.description=description_tip&split.item4.type=PaymentFee&split.item4.account=BA00000000000000000000001&split.item4.reference=reference_fees&split.item4.description=description_fees&split.item5.type=Surcharge&split.item5.account=BA00000000000000000000001&split.item5.reference=reference_surcharge&split.item4.description=description_surcharge" }, "PaymentTransaction": { "AmountsReq": { "Currency": "EUR", "RequestedAmount": 620.00 "TipAmount": 10.00 } } } } }
In the PaymentResponse
note the following:
POIData.POITransactionID.TransactionID
: Transaction identifier for the payment.-
PaymentResult.AmountsResp
:AuthorizedAmount
: total amount of the payment (the sum of the original transaction amount, tip amount, and surcharge amount).TipAmount
: amount of the tip. If the customer didn't add a tip, this field is not included.-
Currency
: currency of the payment.Response.Result
: SuccessResponse.AdditionalResponse
: additional transaction data. Depending on the format you used in the request, you receive either a string of form-encoded key-value pairs or a Base64 string that you need to decode to get a JSON object. This includes:posadditionalamounts.originalAmountValue
: the original transaction amount in minor units.posAmountGratuityValue
: the tip amount in minor units.authorisedAmountValue
: the total authorised amount in minor units, which includes the surcharge amount.
{ "SaleToPOIResponse":{ "MessageHeader":{}, "PaymentResponse":{ "POIData":{ "POIReconciliationID":"1000", "POITransactionID":{ "TimeStamp":"2023-04-12T10:49:53.949Z", "TransactionID":"qwiT001681296593002.RJTPF68B2HXXGN82" } }, "PaymentReceipt":[...], "PaymentResult":{ "AmountsResp":{ "AuthorizedAmount":636.00, "Currency":"EUR", "TipAmount":10 }, ... "PaymentInstrumentData":{...} }, "Response":{ "AdditionalResponse":"...avsResult=0...dcc.converted.amount.currency=GBP&dcc.converted.amount.value=57285&dcc.exchangerate=9040&dcc.markup=300&dcc.org.amount.currency=EUR&dcc.org.amount.value=63365&dcc.source=FX_exchange_rate&expiryMonth=02&expiryYear=2028&fundingSource=CREDIT&giftcardIndicator=false&gratuityAmount=1000&iso8601TxDate=2023-04-12T10%3a49%3a53.949Z&issuerCountry=GB&merchantReference=499&mid=50&offline=false&paymentMethod=mc&paymentMethodVariant=mc&posAmountCashbackValue=0&posAmountGratuityValue=1000&posAuthAmountCurrency=EUR&posAuthAmountValue=63365...&posOriginalAmountValue=62000&posadditionalamounts.gratuityAmount=1000&posadditionalamounts.originalAmountCurrency=EUR&posadditionalamounts.originalAmountValue=62000&pspReference=RJTPF68B2HXXGN82&refusalReasonRaw=APPROVED...&shopperCountry=NL&store=NL_store_1&tc=0BD07A71D6F4ED43&tid=12618765&transactionReferenceNumber=RJTPF68B2HXXGN82&transactionType=GOODS_SERVICES&txdate=12-04-2023&txtime=12%3a49%3a53", "Result":"Success" }, "SaleData":{ "SaleTransactionID":{ "TimeStamp":"2023-04-12T10:49:53.996Z", "TransactionID":"499" } } } } }