Unreferenced Refund
An overview of the Unreferenced Refund request message for Android.
- Overview
- Unreferenced Refund request
- Unreferenced Refund response
- Key to card terminal product categories
- Get Support
Overview
👉 The Unreferenced Refund request allows you to process a refund without a need of prior transaction or an existing order.
The Unreferenced Refund feature is not enabled by default. To activate it, please reach out to your sales representative or contact our support team.
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.
- Unreferenced Refund request originating from the client app to initiate a request for an Unreferenced Refund transaction.
- Unreferenced Refund response originating from the ‘Viva.com Terminal’ application to return the result of an Unreferenced Refund transaction.
The Unreferenced Refund functionality is currently not available in standalone mode.
Unreferenced Refund request
For a typical Unreferenced Refund request, 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' | ✅ | |||
appId | The client app ID. For successful validation, should not be empty. | 'com.example.myapp' | ✅ | |||
action | This parameter is used to define the action for the Unreferenced Refund transaction. For successful validation, should not be empty. | 'unreferenced_refund' | ✅ | |||
amount | The amount to be refunded in cents | '100' | ✅ | 10 | 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' | Boolean | |||
show_transaction_result | A flag indicating if transaction result will be shown. | 'true' | Boolean | |||
aadeProviderId [*] | 👉 Integration with Provider (ΥΠΑΗΕΣ) Set the Unique Number to identify your Provider. To learn more about all licensed AADE providers, please visit this page. 👉 Integration with ΦΗΜΑΣ (Φορολογικός Ηλεκτρονικός Μηχανισμός Ασφαλείας) For integration through ΦΗΜΑΣ, please specify as `aadeProviderId' the value 800 |
Integration with Provider (ΥΠΑΗΕΣ) 999 Integration with ΦΗΜΑΣ (Φορολογικός Ηλεκτρονικός Μηχανισμός Ασφαλείας) 800 |
3 | Numeric | ||
aadeProviderSignatureData [*] | 👉 Integration with Provider (ΥΠΑΗΕΣ) The unencrypted signature that includes the fields below with semicolon as a delimiter “;”: 👉 Integration with ΦΗΜΑΣ (Φορολογικός Ηλεκτρονικός Μηχανισμός Ασφαλείας) Use ECR TOKEN as in A.1098/2023 Request A/S< session number>/F< amount>:978:2 /D< datetime>/R< ecr-id>/H< operator-number>/T0 /M/Q< mac>} Result R/S< session number>/R< ecr-id>/T< receipt-number> /Μ/C00/D< trans-data>{/P< prn-data>}} |
Integration with Provider (ΥΠΑΗΕΣ) AD33729F4ED749928AAFA00B90EE4EA91551BAC1;;20231204080313;1051;10000;2400;12400;POS_1 |
200 | Alphanumeric | ||
aadeProviderSignature [*] | 👉 Integration with Provider (ΥΠΑΗΕΣ) The fields of providerSignatureFields encrypted using a public key and the Elliptic Curve Digital Signature Algorithm (ECDSA): 👉 Integration with ΦΗΜΑΣ (Φορολογικός Ηλεκτρονικός Μηχανισμός Ασφαλείας) Use SessionKey as in A.1098/2023 |
Integration with Provider (ΥΠΑΗΕΣ) o0094r3Yk3KTqASLkW3evlDsnIg/ZAdUUf6UCXDtjqpI/dquzAT4WNX3yzS/GLciVNbT75H4pj8hLOV0EpHtzw==" |
Alphanumeric | |||
callback | The URI callback that will handle the result. For successful validation, should not be empty. | 'mycallbackscheme://result' | ✅ |
[*] 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=unreferenced_refund"
+ "&callback=mycallbackscheme://result"
+ "&amount=100"
+ "&show_receipt="+true
+ "&aadeProviderId=999"
+ "&aadeProviderSignatureData=AD33729F4ED749928AAFA00B90EE4EA91551BAC1;;20231204080313;1051;10000;2400;12400;POS_1"
+ "&aadeProviderSignature=o0094r3Yk3KTqASLkW3evlDsnIg/ZAdUUf6UCXDtjqpI/dquzAT4WNX3yzS/GLciVNbT75H4pj8hLOV0EpHtzw=="
+ "&show_transaction_result="+true));
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);
Unreferenced Refund response
After executing an Unreferenced Refund transaction, the ‘Viva.com Terminal’ application responds with an Unreferenced Refund 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.
An Unreferenced Refund response result for an approved refund transaction looks as follows:
mycallbackscheme://result?accountNumber=476173******0043&action=unreferenced_refund&aid=A0000000031010&amount=-57&authorisationCode=88147&cardType=VISA CREDIT&clientTransactionId=&message=Transaction successful&orderCode=4285118455035794&referenceNumber=88147&rrn=428509088147&shortOrderCode=4285118455&status=success&tid=16035794&transactionDate=2024-10-11T12:16:03.3957993+03:00&transactionId=da3f7c7e-5e59-40f4-92e3-ab3deb479d20&verificationMethod=CONTACTLESS - NO CVM
An Unreferenced Refund response for a successful refund transaction using AADE parameters looks as follows:
mycallbackscheme://result?accountNumber=476173******0043&action=unreferenced_refund&aid=A0000000031010&amount=-57&authorisationCode=88147&cardType=VISA CREDIT&clientTransactionId=&message=Transaction successful&orderCode=4285118455035794&referenceNumber=88147&rrn=428509088147&shortOrderCode=4285118455&status=success&tid=16035794&transactionDate=2024-10-11T12:16:03.3957993+03:00&transactionId=da3f7c7e-5e59-40f4-92e3-ab3deb479d20&verificationMethod=CONTACTLESS - NO CVM&aadeTransactionId=116407412859062859062
It is expected that certain transactions will fail for various reasons. An Unreferenced Refund response result for a failed refund transaction looks as follows:
mycallbackscheme://result?action=unreferenced_refund&amount=57&clientTransactionId=&message=(-4) USER_CANCEL&status=fail&tid=16035794&verificationMethod=
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. | |
'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. | |
Linux Card Terminals | Countertop, IM20, S900, S800, D200. |
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!