Pre-auth request

An overview of the Pre-auth request message for Android.

Overview

👉 The Pre-auth request is used to initiate a pre-authorisation transaction.

The client app must implement a mechanism to send messages using Android intents and URI calls and to receive the result in a custom URI callback.

If you wish to activate preAuth functionality in your terminals, please contact your Viva sales representative.

Pre-auth request

For a typical Pre-auth request, the client app must provide the following information:

Please note: ISV parameters are not included, as pre-authorizations are not supported for card-present payments using the ISV schema

Field Description Example Required Card terminal support Character limit Type
scheme The Viva custom URL scheme, the host and the version. 'vivapayclient://pay/v1' Android Card Terminals'Viva.com Terminal' application for Android
merchantKey The merchant's key. For successful validation, should not be empty.
Deprecated: you may pass any value.
'SG23323424EXS3' Android Card Terminals'Viva.com Terminal' application for Android
appId The client app ID. For successful validation, should not be empty. 'com.example.myapp' Android Card Terminals'Viva.com Terminal' application for Android
action Pre-auth transaction. For successful validation, should not be empty. 'pre_auth' Android Card Terminals'Viva.com Terminal' application for Android
clientTransactionId A unique transaction ID transmitted to the host for storage with the transaction. Note that this value will be provided in the Merchant Reference field provided in the sales export response. '12345678901234567890123456789012' Android Card Terminals'Viva.com Terminal' application for Android 2048
amount Amount in cents without any decimal digits. This value must not be empty and must be an integer larger than zero. '1200' = 12 euro Android Card Terminals'Viva.com Terminal' application for Android 2048 decimal
callback The URI callback that will handle the result. For successful validation, should not be empty. 'mycallbackscheme://result' Android Card Terminals'Viva.com Terminal' application for Android
show_receipt A flag indicating if the receipt and transaction result will be shown. If true both transaction result and receipt will be shown. If false receipt will not be shown and result will be shown if show_transaction_result is true. 'true' 'Viva.com Terminal' application for Android boolean
show_transaction_result A flag indicating whether transaction result will be shown. 'true' 'Viva.com Terminal' application for Android boolean
show_rating A flag indicating if the rating flow will be shown. 'true' 'Viva.com Terminal' application for Android boolean
saleToAcquirerData 👉 JSON converted to base64 string containing additional metadata information

Please visit this link to view a sample of the JSON and generate the encoded data.
ewogICAgImFwcGxpY2F0aW9uSW5mbyI6IHsKICAgICAgICAiZXh0ZXJuYWxQbGF0Zm9ybSI6IHsKICAgICAgICAgICAgIm5hbWUiOiAidml2YS5jb218VGVybWluYWwiLAogICAgICAgICAgICAidmVyc2lvbiI6ICJjb20udml2YXdhbGxldC5zcG9jLnBheWFwcCB2NS4xOS43ICgxMDgxNSkiLAogICAgICAgICAgICAiaW50ZWdyYXRvciI6ICJWaXZhIgogICAgICAgIH0KICAgIH0KfQ== Android Card Terminals'Viva.com Terminal' application for Android Alphanumeric

[*] These parameters are only applicable in Greece

The above parameters must be used to create a URI call. Please see the below example:

Intent payIntent = new Intent(Intent.ACTION_VIEW, Uri.parse(
                        "vivapayclient://pay/v1"
                                + "?merchantKey="MY_MERCHANT_KEY""
                                + "&appId=com.example.myapp"
                                + "&action=pre_auth"
                                + "&clientTransactionId=1234567801234"
                                + "&amount=1200"
                                + "&show_receipt="+true
                                + "&show_transaction_result="+true
                                + "&show_rating="+true
                                + "&saleToAcquirerData=base64EncodedJsonData"
                                + "&callback=mycallbackscheme://result"));

payIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

payIntent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS);
                startActivity(payIntent);

Pre-auth response

After executing a Pre-auth transaction the ‘Viva.com Terminal’ application responds with a Pre-auth response result to indicate if the transaction has been approved or not.

The result is received as a URI in the callback activity intent:

Uri result = getIntent().getData()`

The table below summarises the contents of an approved response.

Field Description Example Card terminal support
callback The URI callback that will handle the result. 'mycallbackscheme://result' Android Card Terminals'Viva.com Terminal' application for Android
status The status of the transaction. 'success' Android Card Terminals'Viva.com Terminal' application for Android
message A string containing information about the transaction status. 'Transaction successful' Android Card Terminals'Viva.com Terminal' application for Android
action Pre-auth transaction. 'pre_auth' Android Card Terminals'Viva.com Terminal' application for Android
clientTransactionId The client transaction ID. '12345678901234567890123456789012' Android Card Terminals'Viva.com Terminal' application for Android
amount The amount in cents without any decimal digits. If action is cancel and amount is not empty must be integer and bigger than zero.
(Used in successful and declined receipts)
'1200' = 12 euro Android Card Terminals'Viva.com Terminal' application for Android
verificationMethod The verification method used. 'CHIP-PIN' Android Card Terminals'Viva.com Terminal' application for Android
rrn The Retrieval Reference Number of the transaction RRN.
(Used in successful and declined receipts)
'123456833121' Android Card Terminals'Viva.com Terminal' application for Android
cardType The card type. 'VISA' Android Card Terminals'Viva.com Terminal' application for Android
accountNumber The card number masked. Note that only the 6 first and the 4 last digits are provided. All other digits are masked with stars.
(Used in successful and declined receipts)
'479275\*\*\*\*\*\*9999' Android Card Terminals'Viva.com Terminal' application for Android
referenceNumber A number with up to 6 digits indicating the transaction's STAN (System Trace Audit Number). '833121' Android Card Terminals'Viva.com Terminal' application for Android
authorisationCode A 6-digit number indicating the transaction's Authorisation code provided by the host. '690882' Android Card Terminals'Viva.com Terminal' application for Android
tid A 12 character string indicating the terminal's TID number. ' 16016684' Android Card Terminals'Viva.com Terminal' application for Android
orderCode The order code. ' 9256110059000200' Android Card Terminals'Viva.com Terminal' application for Android
shortOrderCode 10-digit integer. '1234567890' Android Card Terminals'Viva.com Terminal' application for Android
dccAmount The decimal amount of the transaction expressed in the currency of the customer card.
Present only if the Dynamic Currency Conversion (DCC) was accepted by the customer.
14.80 'Viva.com Terminal' application for Android
dccCurrency Numeric code of the customer card currency, compilant with ISO 4217.
Present only if the Dynamic Currency Conversion (DCC) was accepted by the customer.
985 'Viva.com Terminal' application for Android
exchangeRate The decimal rate of exchange from merchant currency to the customer currency
Present only if the Dynamic Currency Conversion (DCC) was accepted by the customer.
1.2333 'Viva.com Terminal' application for Android
markup The decimal percentage representing the margin applied by the currency conversion operator. Its value is included in the exchangeRate and the dccAmount.
Present only if the Dynamic Currency Conversion (DCC) was accepted by the customer.
3.0 'Viva.com Terminal' application for Android
transactionDate The transaction date in ISO 8601 format.
(Used in successful and declined receipts)
'2019-09-13T12:14:19.8703452+03:00' Android Card Terminals'Viva.com Terminal' application for Android
transactionId A unique identifier for the transaction. 'a78e045c-49c3-4743-9071-f1e0ed71810c' Android Card Terminals'Viva.com Terminal' application for Android
aid A string indicating the AID of the card.
(Used in successful receipts)
'A000000003101001' Android Card Terminals'Viva.com Terminal' application for Android
vatNumber The VAT number of merchant.
(if print VAT is enabled in the 'Viva.com Terminal' application settings)
(Used in successful and declined receipts)
'123412341' Android Card Terminals'Viva.com Terminal' application for Android
address The address of merchant
(if print address is enabled in the 'Viva.com Terminal' application settings)
(Used in successful receipts)
‘Main St 123, 12312 Anytown’ Android Card Terminals'Viva.com Terminal' application for Android
businessDescription Merchant’s Business/Trade/Store name (depending on what option is selected in the 'Viva.com Terminal' application settings),
(Used in successful receipts)
'Wonka Industries' Android Card Terminals'Viva.com Terminal' application for Android
printLogoOnMerchantReceipt A boolean indicating weather the VivaWallet logo should be printed on merchant receipt.
(Used in successful receipts)
'false' Android Card Terminals'Viva.com Terminal' application for Android
merchantReceiptPAN This field contains the value of the PAN (and additional clipping) that should be printed in merchant receipt. If is empty, then apply the default clipping.
(Used in successful receipts)
'629914XXXXXXXXX6770' Android Card Terminals'Viva.com Terminal' application for Android
cardholderReceiptPAN This field contains the value of the PAN (and additional clipping) that should be printed in customer receipt. If is empty, then apply the default clipping. '629914XXXXXXXXX6770' Android Card Terminals'Viva.com Terminal' application for Android
transactionReceiptAcquirerZone If it is not empty then this value should be printed at the end of the customer receipt.
(Used in successful receipts)
'qwerty123456' Android Card Terminals'Viva.com Terminal' application for Android
cardholderReceiptText If is not empty then this value should be printed at the end of the customer receipt.
(Used in successful receipts)
'qwerty123456' Android Card Terminals'Viva.com Terminal' application for Android
merchantReceiptText If is not empty then this value should be printed at the end of the customer receipt.
(Used in successful receipts)
'qwerty123456' Android Card Terminals'Viva.com Terminal' application for Android
cardholderName Name of the cardholder.
(Used in successful receipts)
'JOHN DOE' Android Card Terminals'Viva.com Terminal' application for Android
cardExpirationDate Expiration date of the card (YYMM).
(Used in successful receipts)
'2212' Android Card Terminals'Viva.com Terminal' application for Android
cardholderNameExpirationDateFlags Each char may be 0 (false) or 1 (true) and indicates if the cardholder name and the expiration date should be printed on the merchant/cardholder receipts)

1st char: if 1 then the Cardholder Name should be printed in the merchant's receipt. If 0, then it should not.

2nd char: if 1 then the Cardholder Name should be printed in the cardholder's receipt. If 0, then it should not.

3rd char: if 1 then the Expiration Date should be printed in the merchant's receipt. If 0, then it should not.

4rd char: if 1 then the Expiration Date should be printed in the cardholder's receipt. If 0, then it should not.
(Used in successful receipts)
'1010' Android Card Terminals'Viva.com Terminal' application for Android
needsSignature A boolean indicating if the receipt needs a signature section.
(Used in successful receipts)
false Android Card Terminals'Viva.com Terminal' application for Android
addQRCode A boolean indicating if the order code should be printed as a QR.
(Used in successful receipts)
false Android Card Terminals'Viva.com Terminal' application for Android
terminalSerialNumber The serial number of the terminal.
(Used in successful receipts)
“1234567891“ Android Card Terminals'Viva.com Terminal' application for Android
currency The currency of the transaction.
(Used in successful receipts)
“EUR“ Android Card Terminals'Viva.com Terminal' application for Android
errorText Text to print on the receipt stating the error description and the error ccode.
(Used in declined receipts)
“Transaction failed - Z-3“ Android Card Terminals'Viva.com Terminal' application for Android
applicationVersion The version off the application.
(Used in declined receipts)
'v3.7.0(1956)' Android Card Terminals'Viva.com Terminal' application for Android
oldBalance The old balance of the cardholder.
(Used in successful receipts)
'200' = 2 euro Android Card Terminals'Viva.com Terminal' application for Android
newBalance The new balance of the cardholder.
(Used in successful receipts)
'200' = 2 euro Android Card Terminals'Viva.com Terminal' application for Android
entryMode Indicates the method used for PAN entry to initiate a transaction. You may find all the POS Entry Modes here. '07' Android Card Terminals'Viva.com Terminal' application for Android

A Pre-auth response result for an approved transaction looks as follows:

A sale response for a succesful pre-auth transaction with DCC(Dynamic Currency Conversion) looks as follows:

Key to card terminal product categories

To understand the icons used on the above tables, see the below table.

Product category Terminal models Icon
Android Card Terminals Android Card Terminal Ethernet, Android Card Terminal 4G, Mobile Card Terminal Plus, Mobile Card Terminal. Android Card Terminals
'Viva.com Terminal' application for Android Mini Card Reader, Pocket Card Terminal connected via Bluetooth or USB to the 'Viva.com Terminal' application for Android. Android Card Terminals
Linux Card Terminals Countertop, IM20, S900, S800, D200. Linux Card Terminals

Get Support

If you would like to integrate with Viva, or if you have any queries about our products and solutions, please see our Contact & Support page to see how we can help!