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
- 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. -
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
orsplit.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.
{ "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
: 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.
{ "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" } } } } }