Rebate request

An overview of the Rebate message for Android.

Overview

👉 The Rebate request is utilized to process a rebate to a Visa, Mastercard, or Maestro card (where supported by the customer’s bank).

Rebate functionality is not enabled by default, and is subject to approval.

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.

Rebate functionality is also available standalone

Rebate request

For a typical Rebate request, or refund, the client app must provide the following information:

Field Description Example Required Card terminal support Character limit Type
scheme The Viva's custom URL scheme, the host and the version. 'vivapayclient://pay/v1' ✅ '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' 'viva.com | Terminal' application for Android
appId The client app ID. For successful validation, should not be empty. 'com.example.myapp' ✅ 'viva.com | Terminal' application for Android
action Rebate. For successful validation, should not be empty. 'send_money_rebate' ✅ 'viva.com | Terminal' application for Android
referenceNumber The STAN number of the transaction to be cancelled. If empty, after card presentment, the app will provide a list of the last 3 transactions made with the presented card, allowing the user to select the transaction to be canceled. If action is cancel and if not empty should be integer bigger than zero. '123789' integer (int32)
amount The amount to be refunded in cents '100' ✅ 'viva.com | Terminal' application for Android 10 integer (int32)
sourceCode The store/source code that will be linked to the transaction.
  • If a source code parameter is not specified, the source code assigned to the terminal will automatically be associated with the transaction.
  • When the sourceCode is specified, the transaction will be linked to the sourceCode accordingly.
[A payment source (physical store) that is associated with the transaction]

How to create a payment source for CP payments
'viva.com | Terminal' application for Android 20 integer (int32)
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 if 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
callback The URI callback that will handle the result. For successful validation, should not be empty. 'mycallbackscheme://result' ✅ 'viva.com | Terminal' application for Android
aadeProviderId [*] Unique Number to identify specific Provider (΄ΠΑΗΕΣ):

  • 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'
    Please note that this parameter apply only for Greek merchants.
    Android Card Terminals'viva.com | Terminal' application for Android 3 Numeric
    aadeProviderSignatureData [*] The unencrypted signature that includes the fields below with semicolon as a delimiter “;”:

  • Receipt UID
  • MARK (Unique ID provided by AADE - commonly null as this provider after the end of the transaction)
  • Date and time of the Signature
  • Amount to be paid
  • Sum Amount without TAX
  • VAT percentage
  • Sum Amount with TAX
  • TID
  • AD33729F4ED749928AAFA00B90EE4EA91551BAC1;;20231204080313;1051;10000;2400;12400;POS_1
    Please note that this parameter apply only for Greek merchants.
    Android Card Terminals'viva.com | Terminal' application for Android 200 Alphanumeric
    aadeProviderSignature [*] 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 is sent to POS in base64 format
  • o0094r3Yk3KTqASLkW3evlDsnIg/ZAdUUf6UCXDtjqpI/dquzAT4WNX3yzS/GLciVNbT75H4pj8hLOV0EpHtzw=="
    Please note that this parameter apply only for Greek merchants.
    Android Card Terminals'viva.com | Terminal' application for Android

    [*] These parameters are only applicable in Greece

    The above information elements must create a URI call, i.e.

    Intent payIntent = new Intent(Intent.ACTION_VIEW, Uri.parse( "vivapayclient://pay/v1"
    				+ "?merchantKey="MY_MERCHANT_KEY"
    				+ "&appId=com.example.myapp"
    				+ "&action=send_money_rebate"
    				+ "&callback=mycallbackscheme://result"
    				+ "&amount=100"
            + "&sourceCode=6532"
    				+ "&show_receipt="+true
    				+ "&show_transaction_result="+true
    				+ "&show_rating="+true
                    + "&aadeProviderId=999"
                    + "&aadeProviderSignatureData=AD33729F4ED749928AAFA00B90EE4EA91551BAC1;;20231204080313;1051;10000;2400;12400;POS_1"
                    + "&aadeProviderSignature=o0094r3Yk3KTqASLkW3evlDsnIg/ZAdUUf6UCXDtjqpI/dquzAT4WNX3yzS/GLciVNbT75H4pj8hLOV0EpHtzw=="));
    
    
    payIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    payIntent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS);
    //        Those two flags should be added for paydroid implementations
    //        payIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
    //        payIntent.addFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);
                    startActivity(payIntent);

    Rebate response

    After executing a Rebate transaction, or refund, the ‘viva.com | Terminal’ application responds with a Rebate response result to indicate if the refund 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' 'viva.com | Terminal' application for Android
    status The status of the transaction 'success' 'viva.com | Terminal' application for Android
    message A string containing information about the transaction status. 'Transaction successful' 'viva.com | Terminal' application for Android
    action Rebate transaction. 'send_money_rebate' 'viva.com | Terminal' application for Android
    amount The amount in cents without any decimal digits. '1200' = 12 euro 'viva.com | Terminal' application for Android
    sourceCode The source code associated with the transaction. '2412' 'viva.com | Terminal' application for Android
    cardType The card type. 'Visa' 'viva.com | Terminal' application for Android
    accountNumber The card number. Note that only the 6 first and the 4 last digits are provided. All other digits are masked with stars. '479275\*\*\*\*\*\*9999' 'viva.com | Terminal' application for Android
    tid A 12-character string indicating the terminal's TID number. '16016684' 'viva.com | Terminal' application for Android
    transactionDate The transaction date in ISO 8601 format. '2019-09-13T12:14:19.8703452+03:00' 'viva.com | Terminal' application for Android
    transactionId A unique identifier for the transaction. 'a78e045c-49c3-4743-9071-f1e0ed71810c' 'viva.com | Terminal' application for Android
    aadeTransactionId An AADE-specific transaction ID.

    Format: Acquirer Unique code + RRN + Authorization code.

    Example: ‘116’ + ‘123456833121’ + ‘690882’ = '116123456833121690882'
    '116123456833121690882' Android Card Terminals'viva.com | Terminal' application for Android

    A Rebate response result for an approved refund looks as follows:

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

    It is expected that certain transactions will fail for various reasons. A Rebate response result for a failed refund looks as follows:

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

    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!