Sale Request

An overview of the Sale Request message.

Overview

Please see below for information on configuring the Sale Request, as well as the expected Sale Response.

txSaleRequest

For a typical sale request the client must provide the following information:

Field Type Length (chars) Description Example Required Card terminal support
msgLength String 4 A 4-digit number padded with leading zeros indicating message length minus 4 (including any separators). The request will be rejected if the correct message length is not provided. 0063 Android Card TerminalsLinux Card Terminals
sessionId String 6 A unique number to control integrity of session sequence. 002690 Android Card TerminalsLinux Card Terminals
msgType String 3 200 200
Android Card TerminalsLinux Card Terminals
msgCode String 2 00 00
Android Card TerminalsLinux Card Terminals
uniqueTxnId String 32 A unique transaction ID transmitted to the host for storage with the transaction. Note that this value will be provided in the MerchantTrns field provided in the sales export response. 12345678901234567890123456789012 Android Card TerminalsLinux Card Terminals
amount String variable up to 13 Amount always including 2 decimal digits following the decimal point. A dot must always be used as a decimal point. 124.00
Android Card TerminalsLinux Card Terminals
msgOptions String 4 0000 0000 Android Card TerminalsLinux Card Terminals
Reserved String 0 Empty null Android Card TerminalsLinux Card Terminals
Reserved String 0 Empty null Android Card TerminalsLinux Card Terminals
Reserved String 0 Empty null Android Card TerminalsLinux Card Terminals
Reserved String 0 Empty null Android Card TerminalsLinux Card Terminals
ISV_amount String Variable up to 13 ISV fee amount always including 2 decimal digits following the decimal point. A dot must always be used as a decimal point. 123.00
✅ Required for ISV
Android Card TerminalsLinux Card Terminals
ISV_clientId String 200 The id of the ISV client.
Refer to note below.
qwerty123456
✅ Required for ISV
Android Card TerminalsLinux Card Terminals
ISV_clientSecret String 200 The secret of the ISV client.
Refer to note below.
qwerty123456
✅ Required for ISV
Android Card TerminalsLinux Card Terminals
ISV_sourceCode String 20 The source code of the ISV.
Refer to note below.
[A payment source (physical store) that is associated with a terminal]

How to create a payment source for ISV
✅ Required for ISV
Android Card TerminalsLinux Card Terminals
Receipt_UID String 200 The unique identifier (UID) is a numeric or alphanumeric string that is associated with a single entity within the cashier system. 193302323D532594AD14B669BCCC60C74FCA8BB6
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
MARK String 0 Unique ID provided by AADE. Commonly is null as this provided at the end of each successful transaction. null
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
SignatureDateTime String 200 The Date and time of the Provider's Digital Signature. 20240513134504
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
PaidAmount String 200 The amount to be paid.

This value should be the same as the amount parameter and should be specified without any special character, such as comma (,) or point (.)
12400
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
AmountWithoutTax String 200 The amount without TAX to be paid.

This value should be specified without any special character, such as comma (,) or point (.)
10000
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
VAT String 200 The value of VAT percentage that applied to the total amount.

This value should be specified without any special character, such as comma (,) or point (.)

If different value of TAX applied to the items of the transaction, then should be specified in this parameter, the highest value of TAX.
24
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
AmountWithTax String 200 The amount with TAX to be paid.

This value should be specified without any special character, such as comma (,) or point (.)
12400
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
POSTerminalID String 200 The POS ID through which the transaction will be handled.

The value of POS ID is NOT be the Device Serial Number, and can be found through the Viva Softpos Application Settings.
16000198
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
Reserved String 0 Empty null
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
Reserved String 0 Empty null
Required for AADE Integration

👉 Applicable only in Greece
Linux Card Terminals
ProviderID String 200 The ID of the ΥΠΑΗΕΣ Provider that generates the Digital Signature for this transaction.

  • VivaDemo = 999
  • SoftOne = 101
  • EnterSoft = 102
  • Impact = 103
  • Epsilon Net = 104
  • Novus Conceptus = 105
  • Cloud Services IKE = 106
  • Primer Software = 107
  • ILYDA = 108
  • Prosvasis = 109
  • MAT = 110
  • Simply = 111
  • Kappa = 112
  • SBZ = 113
  • OneSys = 114
  • ORIAN = 115
  • TESAE = 116
  • Karpodinis = 117
  • Cloud T = 118
  • Πάροχος Λύσεων Πληροφορικής Α.Ε. = 119
  • 999
    Required for AADE Integration

    👉 Applicable only in Greece
    Linux Card Terminals
    Reserved String 0 Empty null
    Required for AADE Integration

    👉 Applicable only in Greece
    Linux Card Terminals
    Reserved String 0 Empty null
    Required for AADE Integration

    👉 Applicable only in Greece
    Linux Card Terminals
    aadeProviderSignature String 200 The fields of providerSignatureFields encrypted using a public key and the Elliptic Curve Digital Signature Algorithm (ECDSA):

  • Algorithm: ECDSA
  • Curve: NISTP256
  • HASH: SHA256

    The signature should be sent to POS in base64 format.
  • MEUCIQDHGhz2KQ+gddCsryDxcF69wW3o7C5WpuULHJ8DPeuLBgIgVxgCbh+OFtuZCwAOp7O8kJ+ShPlcpw84RG2jLBAWp2c=
    Required for AADE Integration

    👉 Applicable only in Greece
    Linux Card Terminals
    protocol String 20 The protocol used (for internal use only) 'ecr_default' Android Card Terminals

    ISV parameter info:

    • ISV_clientId can be found under Settings > API access in the viva banking app
    • ISV_clientSecret as above.
    • ISV_sourceCode is the payment source for ISV set up under Sales > Physical Payments > Stores.

    The above information elements must be joined into one single string using ‘|’ as a separator.

    If the resulting string gets appropriately transmitted to the terminal, the terminal will respond with a txResponse message (200).

    A sale request for a successful sale transaction (without using AADE parameters) looks as follows:

    A sale request for a successful sale transaction using AADE parameters looks as follows:

    Notes

    txSaleResponse

    After executing a Sale transaction the terminal responds with a txSaleResponse to indicate if the transaction has been approved or not.

    The table below summarises the contents of the response.

    Field Length (chars) Description Example Card terminal support
    msgLength 4 A 4-digit number padded with leading zeros indicating the length of the message that follows (including separators). Before considering the msgLength value, please make sure that you've decoded the terminal response with UTF-8. '0129' Android Card TerminalsLinux Card Terminals
    seqTxnId 6 A 6 digit number matching the value sent in seqTnxNum field of the preceding txReady message. 000032 Android Card TerminalsLinux Card Terminals
    msgTypeResp 3 210 210 Android Card TerminalsLinux Card Terminals
    msgCodeResp 2 00 00 Android Card TerminalsLinux Card Terminals
    respCodeResp 2 Approval status. '00' indicates approval. All other values indicate failure codes. See failure code table at the end. 00 Android Card TerminalsLinux Card Terminals
    respMessageResp variable
    up to 60
    A string containing information on how the transaction was made, the card holder verification method used, the RRN and the Auth.code provided by the host. CHIP/PIN~RRN:123456833121 Android Card TerminalsLinux Card Terminals
    cardTypeResp variable A string indicating the card type. VISA Android Card TerminalsLinux Card Terminals
    accNumberResp variable A string indicating the card number. Note that only the 6 first and the 4 last digits are provided. All the rest digits are masked with stars. 479275******9999 Android Card TerminalsLinux Card Terminals
    refNumResp 6 A 6-digit number indicating the transaction's STAN number. 833121 Android Card TerminalsLinux Card Terminals
    authCodeResp 6 A 6-digit number indicating the transaction's Authorisation code provided by the host. 690882 Android Card TerminalsLinux Card Terminals
    batchNumResp 6 A 6-digit number indicating the batch number. Not to be taken into account. 000001 Android Card TerminalsLinux Card Terminals
    amountResp variable The transaction's amount. 123.00 Android Card TerminalsLinux Card Terminals
    msgOptResp 4 The Message Options.

    It will be ever static and should be ignored.
    1010 Android Card TerminalsLinux Card Terminals
    tipAmountResp 2 00 (currently not used) 00 Android Card TerminalsLinux Card Terminals
    foreignAmountResp 2 00 (currently not used) 00 Android Card TerminalsLinux Card Terminals
    foreignCurrencyCode 2 00 (currently not used) 00 Android Card TerminalsLinux Card Terminals
    exchangeRageInclMarkupResp 2 00 (currently not used) 00 Android Card TerminalsLinux Card Terminals
    dccMarkcupPercentage 2 00 (currently not used) 00 Android Card TerminalsLinux Card Terminals
    dccExchangeDateOfRateResp 2 00 (currently not used) 00 Android Card TerminalsLinux Card Terminals
    eftTidResp 12 A 12 character string indicating the terminal's TID number, padded with spaces if required. 16016684 Android Card TerminalsLinux Card Terminals
    orderCode 16 Can be provided instead of or together with a refNum number. If a txnDateFrom/txnDateTo is provided, then the returned transaction results are bound by these dates, otherwise the last three transactions are returned. 1069120310000201 Android Card TerminalsLinux Card Terminals
    shortOrderCode 10 Can be provided instead of or together with a refNum number. If a txnDateFrom/txnDateTo is provided, then the returned transaction results are bound by these dates, otherwise the last three transactions are returned. 1069120310 Android Card Terminals
    MerchantReceiptPAN variable up to 19 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.

    Note: this parameter is returned only for c-tap cards (meal vouchers, etc.)
    629914XXXXXXXXX6770 Linux Card Terminals
    CardholderReceiptPAN variable up to 19 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.

    Note: this parameter is returned only for c-tap cards (meal vouchers, etc.)
    629914XXXXXXXXX6770 Linux Card Terminals
    CardholderReceiptText variable up to 200 If is not empty then this value should be printed at the end of the customer receipt.

    Note: this parameter is returned only for c-tap cards (meal vouchers, etc.)
    qwerty123456 Linux Card Terminals
    TransactionReceiptAcquirerZone variable up to 200 If it is not empty then this value should be printed at the end of the customer receipt.

    Note: this parameter is returned only for c-tap cards (meal vouchers, etc.)
    qwerty123456 Linux Card Terminals
    CardholderName variable up to 50 Name of the cardholder.

    Note: this parameter is returned only for c-tap cards (meal vouchers, etc.)
    CARDHOLDER NAME Linux Card Terminals
    CardExpirationDate 4 Expiration date of the card (YYMM).

    Note: this parameter is returned only for c-tap cards (meal vouchers, etc.)
    2212 Linux Card Terminals
    CardholderName&ExpirationDateFlags 4 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.

    4th char: if 1 then the Expiration Date should be printed in the cardholder's receipt. If 0, then it should not.

    Note: this parameter is returned only for c-tap cards (meal vouchers, etc.)
    1010 Linux Card Terminals
    transactionId variable up to 50 The id of the transaction. b3e2744a-71ec-4d51-a856-c2f70249bdd4 Android Card TerminalsLinux Card Terminals
    transactionDateTime variable up to 50 The date of the transaction. 2021-12-15T16:34:49.4495733+02:00 Android Card TerminalsLinux Card Terminals
    transactionType variable up to 2 The type of the transaction. You can see all the possible transaction types in the Transaction Type Table 1 Android Card TerminalsLinux Card Terminals
    Reserved 0 Currently not used. null Linux Card Terminals
    Reserved 0 Currently not used. null Linux Card Terminals
    Reserved 0 Currently not used. null Linux Card Terminals
    Reserved 0 Currently not used. null Linux Card Terminals
    aadeTransactionId variable up to 50 An AADE-specific transaction ID.

    Format
    Acquirer Unique code + RRN + Authorization code.

    Example
    116 + 123456833121 + 690882 = 116123456833121690882
    116413607959451959451 Linux Card Terminals
    paidAmount variable The transaction's amount. 12300 Linux Card Terminals
    transactionDateTime variable up to 50 The date of the transaction. 2021-12-15T16:34:49.4495733+02:00 Linux Card Terminals

    Linux Card Terminals:

    A txSaleResponse for an approved transaction (without using AADE parameters) looks as follows:

    A txSaleResponse for an approved transaction (with AADE parameters) looks as follows:

    Android Card Terminals:

    It is expected that certain transactions will fail for various reasons. A txSaleResponse for a failed transaction looks as follows:

    The structure of the message is the same as in the case of an approved transaction.

    Differences are limited to two specific fields.

    Obviously refNumResp and authCodeResp contain zeros since there is no STAN code available, nor an authorisation code.

    Failure reasons and ISO codes

    The table below summarises the failure reasons that can be provided by the terminal.

    CodeDescriptionEvent
    51Declined By HostDeclined by the issuer
    UDUnsupported CardCard is not supported
    UCUser CancelledUser pressed cancel or the user failed to present card in due time
    LCLost Carrier (Communication Error)No network
    TOTime Out (Communication Error)Time out with host
    CECommunication Error (Other)No connectivity
    NDCommunication Error (Other)Request failed
    NAHost Not AvailableHost is not unreachable
    IMInvalid MAC received from host-
    UNError – Wrong Transaction-
    ECExpired CardExpired Card
    XCTransaction approved. EMV fail. AutoreversalTransaction approved but automatically canceled
    RCError during card readingAn error occurred while reading the card.
    NOError after void requestNo transactions found.
    IPInvalid ParametersA parameter in request is wrong.
    EDDeclined by ECR/ERP-
    IDInvalid Reversal Data-
    19Try another card-
    LRNFLast receipt not found-
    IBBatch Error-
    PFParameters failed-
    01Printing failedOut of paper
    02Printing failedLow battery
    03Printing failedOther
    -An Error OccurredNo other error code applicable to issue

    Notes

    IsoCodeDescription
    10001ReferToCardIssuer
    10003InvalidMerchant
    10004PickupCard
    10005DoNotHonor
    10006GeneralError
    10012InvalidTransaction
    10013InvalidAmount
    10014InvalidAccountNumber
    10030FormatError
    10041LostCard
    10043StolenCard
    10051InsufficientFunds
    10054ExpiredCard
    10055IncorrectPin
    10057TransactionNotPermittedToCardHolder
    10058TransactionNotPermittedToAcquirerOrTerminal
    10061ActivityAmountLimitExceeded
    10062RestrictedCard
    10063SecurityViolation
    10065ActivityCountLimitExceeded
    10068LateResponse
    10070CallIssuer
    10075PinEntryTriesExceeded
    10086PinValidationNotPossible
    10087PurchaseAmountOnlyNoCashBackAllowed
    10090CutOffInProgress
    10094DuplicateTransmissionDetected
    10096SystemMalfunction
    10199Empty
    10200Unmapped
    *Anyother

    Transaction Types Table

    Transaction type Id
    PREPARE_SALE 0
    SALE 1
    CANCEL 2
    PREAUTH 3
    CAPTURE 4
    CANCEL_PREAUTH 5
    SALE_ENGINE 6
    EXECUTE_SALE 7
    SCA_SALE 8
    SCA_PREAUTH 9
    REFUND 11

    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!