Adyen-for-platform icon

Tipping

Implement tipping (gratuity) in your payment flow.

When a customer adds a tip to their payment, it is booked to your liable account by default. However, you can book the entire tip amount directly to your user's balance account by providing an additional split item in the payment request.

You can only book the tip to your user's balance account when you use one of the following methods of tipping:

Book the tip to your user

  1. When splitting a payment, add a split item for the tip.

    When adding a new split item, always include this in the total number of split items specified in the split.nrOfItems field.

  2. For the split item of the tip, specify:

    Key Description Example
    split.item[ITEM_NUMBER].type The type of split. Set this to Tip. split.item3.type=Tip
    split.item[ITEM_NUMBER].account Account that will receive the tip. This is the balanceAccountID of one of your user's balance accounts.
    You cannot split the tip between multiple balance accounts.
    split.item3.account=BA00000000000000000000001
    split.item[ITEM_NUMBER].reference Your reference for the tip, reflected in the Balance Platform Accounting Report. split.item3.reference=reference_tip
    split.item[ITEM_NUMBER].description Your description for the tip, reflected in the Balance Platform Accounting Report. split.item3.description=description_tip

    You do not need to include the tip amount in the split.totalAmount or split.item[ITEM_NUMBER].amount fields, since the tip amount may not be known when creating the payment request.

For example, a payment of EUR 630.00 is split into:

  • EUR 600.00 to be paid 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 paid to your user's first balance account as the tip.
  • EUR 20.00 to be paid to your liable account as your platform's commission.

In this case, set the split.nrOfItems to 4 and split.totalAmount to 62000 (the amounts for the tip and the payment fee are not known when sending the payment request).

The following tabs show how to book the tip to your user's balance account when the customer tips from the POS app and from the terminal.

Note that the request includes an additional TipAmount parameter in the AmountsReq object, where you can specify the tip amount.

Split instructions for the tip when tipping from the POS app
Expand view
Copy link to code block
Copy code
Copy code
{
"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=3&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"
},
"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:

    • TipAmount: amount of the tip. If the customer didn't add a tip, this field is not included.
    • AuthorizedAmount: total amount of the payment (original transaction amount plus tip amount).
    • Currency: currency of the payment.
    • Response.Result: Success
    • Response.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.
Response
Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIResponse":{
"MessageHeader":{...},
"PaymentResponse":{
"POIData":{
"POIReconciliationID":"1000",
"POITransactionID":{
"TimeStamp":"2023-03-14T16:10:31.279Z",
"TransactionID":"qwiT001678810231002.8826788102602493"
}
},
"PaymentReceipt":[...],
"PaymentResult":{
"AmountsResp":{
"AuthorizedAmount":630,
"Currency":"EUR",
"TipAmount":10
},
...
"PaymentAcquirerData":{
"AcquirerPOIID":"S1F2-000158212618765",
"AcquirerTransactionID":{
"TimeStamp":"2023-03-14T16:10:31.279Z",
"TransactionID":"8826788102602493"
},
"ApprovalCode":"123456",
"MerchantID":"AdyenTechSupport_NainaBP_TEST"
},
"PaymentInstrumentData":{...}
},
"Response":{
"AdditionalResponse":"AID=A000000004101001&acquirerCode=TestPmmAcquirer&acquirerResponseCode=APPROVED&applicationLabel=mc%20en%20gbr%20gbp&applicationPreferredName=MCENGBRGBP&authCode=123456&avsResult=0%20Unknown&backendGiftcardIndicator=false&batteryLevel=2%25&cardBin=541333&cardHolderVerificationMethodResults=420300&cardIssueNumber=33&cardIssuerCountryId=826&cardScheme=mc&cardSummary=9999&cardType=mc&cvcResult=0%20Unknown&expiryMonth=02&expiryYear=2028&fundingSource=CREDIT&giftcardIndicator=false&gratuityAmount=1000&iso8601TxDate=2023-03-14T16%3a10%3a31.279Z&issuerCountry=GB&merchantReference=565&mid=50&offline=false&paymentMethod=mc&paymentMethodVariant=mc&posAmountCashbackValue=0&posAmountGratuityValue=1000&posAuthAmountCurrency=EUR&posAuthAmountValue=63000&posEntryMode=CLESS_CHIP&posOriginalAmountValue=62000&posadditionalamounts.gratuityAmount=1000&posadditionalamounts.originalAmountCurrency=EUR&posadditionalamounts.originalAmountValue=62000&pspReference=8826788102602493&refusalReasonRaw=APPROVED&retry.attempt1.acquirer=TestPmmAcquirer&retry.attempt1.acquirerAccount=TestPmmAcquirerAccount&retry.attempt1.rawResponse=APPROVED&retry.attempt1.responseCode=Approved&shopperCountry=NL&store=NL_store_1&tc=D23562430A4F269E&tid=12618765&transactionReferenceNumber=8826788102602493&transactionType=GOODS_SERVICES&txdate=14-03-2023&txtime=17%3a10%3a31",
"Result":"Success"
},
"SaleData":{
"SaleTransactionID":{
"TimeStamp":"2023-03-14T16:10:31.537Z",
"TransactionID":"565"
}
}
}
}
}