If you are currently using 5.x of the Android SDK, take a look at the migration guide to 6.x
The new generation of Handpoint APIs and SDKs are engineered to make your life simpler and happier.
<dependency>
<groupId>com.handpoint.api</groupId>
<artifactId>sdk</artifactId>
<version>[6.0.0,7.0.0)</version>
<type>aar</type>
</dependency>
implementation 'com.handpoint.api:sdk:6.+'
Version 6.0.0 introduces a well defined, typed, way of passing extra values, options, parameters or flags to the financial transactions.
We have unified all the extra and optional parameters in an Options object. Different operations have different options.
If you use a customer reference:
options.setCustomerReference("Your customer reference");
If you need Multi MID / Custom merchant Authentication:
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential.setMerchantId(mid);
//Optionally
credential.setTerminalId(tid);
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
options.setMerchantAuth(auth);
If you need to enable pin bypass:
options.setPinBypass(true);
If you want to specify the budget period Only available for SureSwipe:
options.setBudgetNumber(YOUR_BUDGET_NUMBER);
If you want to specify tip options Only available for PAX and Telpo terminals:
TipConfiguration config = new TipConfiguration();
//Optionally
config.setHeaderName(HEADER);
//Optionally
config.setFooter(FOOTER);
//Optionally
config.setEnterAmountEnabled(true);
//Optionally
config.setSkipEnabled(true);
//Optionally
config.setTipPercentages(percentages);
options.setTipConfiguration(config);
Alternatively, you can set the tip amount directly:
options.setTipConfiguration(new TipConfiguration(AMOUNT));
Finally:
api.sale(amount, currency, options);
If you use a customer reference:
options.setCustomerReference("Your customer reference");
If you need Multi MID / Custom merchant Authentication:
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential.setMerchantId(mid);
//Optionally
credential.setTerminalId(tid);
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
options.setMerchantAuth(auth);
If you need to enable pin bypass:
options.setPinBypass(true);
Finally:
api.refund(amount, currency, options);
If you use a customer reference:
options.setCustomerReference("Your customer reference");
Your test payments are sent against a test server on the Handpoint side which simulates the behavior of an acquiring bank. Funds are not moved and sensitive data from the card is fully encrypted. You can use trigger amounts to generate some specific responses from our server:
Sale amounts | |
---|---|
Amount | Behaviour |
37.79 | Issuer response code = 01 (Refer to issuer) |
37.84 | Issuer response code = 05 (Not authorized) |
37.93 | Issuer response code = 04 (Pick up card) |
37.57 | Request is partially approved |
37.68 | Request timeout |
This tutorial is guiding you through all the required steps to create a basic payment application for Android Payment devices such as PAX and Telpo.
The new generation of Handpoint SDK's is designed to make your life easier. Simple and created for humans, it does not require any specific knowledge of the payment industry to be able to start accepting credit/debit card transactions.
At Handpoint we take care of securing every transaction so you don´t have to worry about it while creating your application. We encrypt data from the payment terminal to the bank with our point-to-point encryption solution. Our platform is always up to the latest PCI-DSS security requirements.
Please, start an operation (sale,refund etc.) ONLY if you have received the InitialisationComplete message from the currentTransactionStatus method
We strongly recommend you add the following to your main <activity>:
android:launchMode="singleTask"
android {
defaultConfig {
minSdkVersion 22 //Required to support all PAX & Telpo models
targetSdkVersion 29
multiDexEnabled true
}
packagingOptions {
pickFirst '**/*.so'
exclude 'META-INF/*'
exclude '**/anim/*.xml'
exclude '**/layout/*.xml'
exclude 'resources.arsc'
exclude 'AndroidManifest.xml'
exclude ‘**/animator/*.xml'
}
}
Create a new java class called HandpointDelegate.java and include com.handpoint.api.* as a dependency:
package com.yourpackage.name;
import com.handpoint.api.HandpointCredentials;
import com.handpoint.api.Hapi;
import com.handpoint.api.HapiFactory;
import com.handpoint.api.shared.ConnectionMethod;
import com.handpoint.api.shared.ConnectionStatus;
import com.handpoint.api.shared.Currency;
import com.handpoint.api.shared.Device;
import com.handpoint.api.shared.Events;
import com.handpoint.api.shared.SignatureRequest;
import com.handpoint.api.shared.StatusInfo;
import com.handpoint.api.shared.TipConfiguration;
import com.handpoint.api.shared.TransactionResult;
import com.handpoint.api.shared.agreements.Acquirer;
import com.handpoint.api.shared.agreements.Credential;
import com.handpoint.api.shared.agreements.MerchantAuth;
import com.handpoint.api.shared.options.SaleOptions;
import java.math.BigInteger;
import java.util.Arrays;
import java.util.List;
//Check all the events available in the Events interface.
//If you want to subscribe to more events, just add to the list of implemented interfaces.
public class HandpointDelegate implements Events.Required, Events.ConnectionStatusChanged, Events.CurrentTransactionStatus {
private Hapi api;
public HandpointDelegate(Context context) {
initApi(context);
}
public void initApi(Context context) {
String sharedSecret = "0102030405060708091011121314151617181920212223242526272829303132";
HandpointCredentials handpointCredentials = new HandpointCredentials(sharedSecret);
this.api = HapiFactory.getAsyncInterface(this, context, handpointCredentials);
// The api is now initialized. Yay! we've even set default credentials.
// The shared secret is a unique string shared between the payment terminal and your application, it is unique per merchant.
// You should replace this default shared secret with the one sent by the Handpoint support team.
//Since we're running inside the terminal, we can create a device ourselves and connect to it
Device device = new Device("some name", "address", "", ConnectionMethod.ANDROID_PAYMENT);
this.api.connect(device);
}
@Override
public void connectionStatusChanged(ConnectionStatus status, Device device) {
if (status == ConnectionStatus.Connected) {
//Connection Status connected
}
}
@Override
public void deviceDiscoveryFinished(List<Device> devices) {
// This event can be safely ignored for a PAX/Telpo integration
}
public boolean pay() {
return this.api.sale(new BigInteger("1000"), Currency.GBP);
// Let´s start our first payment of 10 pounds
// Use the currency of the country in which you will be deploying terminals
}
public boolean payWithOptions() {
SaleOptions options = new SaleOptions();
// Adding tipping
TipConfiguration config = new TipConfiguration();
//Optionally
config.setHeaderName("HEADER");
//Optionally
config.setFooter("FOOTER");
//Optionally
config.setEnterAmountEnabled(true);
//Optionally
config.setSkipEnabled(true);
//Optionally
config.setTipPercentages(Arrays.asList(5, 10, 15, 20));
options.setTipConfiguration(config);
// Adding Multi MID / Custom merchant Authentication
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(Acquirer.SANDBOX);
//Optionally
credential.setMid("mid");
//Optionally
credential.setTid("tid");
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
options.setMerchantAuth(auth);
//Add a customer reference
options.setCustomerReference("Your customer reference");
//Enable pin bypass
options.setPinBypass(true);
//Enable signature bypass
options.setSignatureBypass(true);
//Define a budget number
options.setBudgetNumber("YOUR_BUDGET_NUMBER");
return this.api.sale(new BigInteger("1000"),Currency.GBP, options);
}
@Override
public void currentTransactionStatus(StatusInfo statusInfo, Device device) {
if (statusInfo.getStatus() == StatusInfo.Status.InitialisationComplete) {
// The StatusInfo object holds the different transaction statuses like reading card, pin entry, etc.
// Let's launch a payment
pay();
}
}
@Override
public void signatureRequired(SignatureRequest signatureRequest, Device device) {
// This event can be safely ignored for a PAX/Telpo integration
// The complete signature capture process is already handled in the sdk, a dialog will prompt the user for a signature if required.
// If a signature was entered, it should be printed on the receipts.
}
@Override
public void endOfTransaction(TransactionResult transactionResult, Device device) {
// The TransactionResult object holds details about the transaction as well as the receipts
// Useful information can be accessed through this object like the transaction ID, the amount, etc.
}
@Override
public void transactionResultReady(TransactionResult transactionResult, Device device) {
// Pending TransactionResult objects will be received through this event if the EndOfTransaction
// event was not delivered during the transaction, for example because of a network issue
// For this sample app we are not going to implement this event
}
public void disconnect(){
this.api.disconnect();
//This disconnects the connection
}
}
Sort of. With the above tutorial you've done a basic integration that can perform sale transactions.
Explore the rest of the documentation to see more transaction types supported and possibilities.
This tutorial is guiding you through all the required steps to create a basic payment application for Android devices integrated with a HiLite or Hi5 payment terminal.
The new generation of Handpoint SDK's is designed to make your life easier. Simple and created for humans, it does not require any specific knowledge of the payment industry to be able to start accepting credit/debit card transactions.
At Handpoint we take care of securing every transaction so you don´t have to worry about it while creating your application. We encrypt data from the payment terminal to the bank with our point-to-point encryption solution. Our platform is always up to the latest PCI-DSS security requirements.
Please, start an operation (sale,refund etc.) ONLY if you have received the InitialisationComplete message from the currentTransactionStatus method
We strongly recommend you add the following to your main <activity>:
android:launchMode="singleTask"
android {
defaultConfig {
minSdkVersion 22 //change the SDK version to the one corresponding to the device you are using
targetSdkVersion 29
multiDexEnabled true
}
packagingOptions {
pickFirst '**/*.so'
exclude 'META-INF/*'
exclude '**/anim/*.xml'
exclude '**/layout/*.xml'
exclude 'resources.arsc'
exclude 'AndroidManifest.xml'
exclude ‘**/animator/*.xml'
}
}
Create a new java class called HandpointDelegate.java and include com.handpoint.api.* as a dependency:
package com.yourpackage.name;
import android.content.Context;
import com.handpoint.api.HandpointCredentials;
import com.handpoint.api.Hapi;
import com.handpoint.api.HapiFactory;
import com.handpoint.api.shared.ConnectionMethod;
import com.handpoint.api.shared.ConnectionStatus;
import com.handpoint.api.shared.Currency;
import com.handpoint.api.shared.Device;
import com.handpoint.api.shared.Events;
import com.handpoint.api.shared.SignatureRequest;
import com.handpoint.api.shared.StatusInfo;
import com.handpoint.api.shared.TransactionResult;
import java.math.BigInteger;
import java.util.List;
//Check all the events available in the Events interface.
//If you want to subscribe to more events, just add to the list of implemented interfaces.
public class HandpointDelegate implements Events.Required, Events.ConnectionStatusChanged, Events.CurrentTransactionStatus {
private Hapi api;
public HandpointDelegate(Context context) {
initApi(context);
}
public void initApi(Context context) {
String sharedSecret = "0102030405060708091011121314151617181920212223242526272829303132";
HandpointCredentials handpointCredentials = new HandpointCredentials(sharedSecret);
this.api = HapiFactory.getAsyncInterface(this, context, handpointCredentials);
// The api is now initialized. Yay! we've even set a shared secret!
// The shared secret is a unique string shared between the card reader and your mobile application
// It prevents other people to connect to your card reader
// You have to replace this default shared secret by the one sent by our support team
// The shared secret is unique per merchant (not per terminal)
//Now we need to find our device and connect to it
discoverDevices();
}
// Now we need to connect to a device to start taking payments.
// Let's search for them:
public void discoverDevices() {
this.api.searchDevices(ConnectionMethod.BLUETOOTH);
// This triggers the asynchronous search for all the devices around that haven't been paired.
// You could, alternatively, search for the already paired devices
// List<Device> devices = this.api.getPairedDevices(ConnectionMethod.BLUETOOTH);
// Now:
// selectDeviceAndConnect(devices);
// You'll receive the devices found through deviceDiscoveryFinished method.
// See: https://handpoint.com/docs/device/Android/#elem_eventsDeviceDiscoveryFinished
}
@Override
public void deviceDiscoveryFinished(List<Device> devices) {
selectDeviceAndConnect(devices);
}
private void selectDeviceAndConnect(List<Device> devices) {
for (Device device : devices) {
if (device.getName() != null) {
// All the devices here are datecs devices
if (/* Fill your logic here */) {
this.api.connect(device);
// Now take a look at connectionStatusChanged method
break;
}
}
}
}
//Potentially, if you know the MAC address of the device you want to connect to, you can skip the search and do it this way
public void connect() {
Device device = new Device("PP0513901435", "68:AA:D2:00:D5:27", "", ConnectionMethod.BLUETOOTH);
//The Address always has to be written in UPPER CASE
//new Device("name", "address", "port", ConnectionMethod.BLUETOOTH);
this.api.connect(device);
}
@Override
public void connectionStatusChanged(ConnectionStatus status, Device device) {
if (status == ConnectionStatus.Connected) {
// Connected to device
}
}
public boolean pay() {
return this.api.sale(new BigInteger("1000"), Currency.GBP);
// Let´s start our first payment of 10 pounds
}
@Override
public void currentTransactionStatus(StatusInfo statusInfo, Device device) {
if (statusInfo.getStatus() == StatusInfo.Status.InitialisationComplete) {
// The StatusInfo object holds the different transaction statuses like reading card, pin entry, etc.
// Let's launch a payment
pay();
}
}
@Override
public void signatureRequired(SignatureRequest signatureRequest, Device device) {
// You'll be notified here if a sale process needs a signature verification
// A signature verification is needed if the cardholder uses an MSR or a chip & signature card
// This method will not be invoked if a transaction is made with a Chip & PIN card
// At this step, you are supposed to display the merchant receipt to the cardholder on the android device
// The cardholder must have the possibility to accept or decline the transaction
// If the cardholder clicks on decline, the transaction is VOID
// If the cardholder clicks on accept he is then asked to sign electronically the receipt
this.api.signatureResult(true);
// This line means that the cardholder ALWAYS accepts to sign the receipt
// For this sample app we are not going to implement the whole signature process
}
@Override
public void endOfTransaction(TransactionResult transactionResult, Device device) {
// The object TransactionResult stores the different receipts
// Other information can be accessed through this object like the transaction ID, the amount...
}
@Override
public void transactionResultReady(TransactionResult transactionResult, Device device) {
// Pending TransactionResult objects will be received through this event if the EndOfTransaction
// event was not delivered during the transaction, for example because of a network issue.
// For this sample app we are not going to implement this event.
}
public void disconnect() {
this.api.disconnect();
//This disconnects the connection
}
}
Note about reconnections: By default, the SDK will automatically reconnect to the last known device when the connection is lost.If you want to change this behaviour set the property Settings.AutomaticReconnection in HapiManager to false.
Sort of. With the above tutorial you've done a basic integration that can perform sale transactions.
Explore the rest of the documentation to see more transaction types supported and possibilities.
This tutorial is guiding you through all the required steps to integrate with a Handpoint (PAX, Telpo or Datecs) payment terminal, from your Android application, through the internet. CLOUD will be the ConnectionMethod of choice for this guide. With this connection method you become the client in a client - server connection. There needs to be another app with one of our SDKs that is active and keeping the connection open.
The new generation of Handpoint SDK's is designed to make your life easier. Simple and created for humans, it does not require any specific knowledge of the payment industry to be able to start accepting credit/debit card transactions.
At Handpoint we take care of securing every transaction so you don´t have to worry about it while creating your application. We encrypt data from the payment terminal to the bank with our point-to-point encryption solution. The platform is always up to the latest PCI-DSS security requirements.
Please, start an operation (sale,refund etc.) ONLY if you have received the InitialisationComplete message from the currentTransactionStatus method
android {
defaultConfig {
minSdkVersion 22 //Required to support all PAX & Telpo models
targetSdkVersion 29
multiDexEnabled true
}
packagingOptions {
pickFirst '**/*.so'
exclude 'META-INF/*'
exclude '**/anim/*.xml'
exclude '**/layout/*.xml'
exclude 'resources.arsc'
exclude 'AndroidManifest.xml'
exclude ‘**/animator/*.xml'
}
}
Create a new java class called HandpointDelegate.java and include com.handpoint.api.* as a dependency:
package com.yourpackage.name;
import android.content.Context;
import com.handpoint.api.HandpointCredentials;
import com.handpoint.api.Hapi;
import com.handpoint.api.HapiFactory;
import com.handpoint.api.shared.ConnectionMethod;
import com.handpoint.api.shared.ConnectionStatus;
import com.handpoint.api.shared.Currency;
import com.handpoint.api.shared.Device;
import com.handpoint.api.shared.Events;
import com.handpoint.api.shared.SignatureRequest;
import com.handpoint.api.shared.StatusInfo;
import com.handpoint.api.shared.TipConfiguration;
import com.handpoint.api.shared.TransactionResult;
import com.handpoint.api.shared.agreements.Acquirer;
import com.handpoint.api.shared.agreements.Credential;
import com.handpoint.api.shared.agreements.MerchantAuth;
import com.handpoint.api.shared.options.SaleOptions;
import java.math.BigInteger;
import java.util.Arrays;
import java.util.List;
//Check all the events available in the Events interface.
//If you want to subscribe to more events, just add to the list of implemented interfaces.
public class HandpointDelegate implements Events.Required, Events.ConnectionStatusChanged, Events.CurrentTransactionStatus {
private Hapi api;
public HandpointDelegate(Context context) {
initApi(context);
}
public void initApi(Context context) {
String sharedSecret = "0102030405060708091011121314151617181920212223242526272829303132";
String merchantApiKey = "This-is-my-api-key-provided-by-Handpoint";
HandpointCredentials handpointCredentials = new HandpointCredentials(sharedSecret, merchantApiKey);
this.api = HapiFactory.getAsyncInterface(this, context, handpointCredentials);
// The api is now initialized. Yay! we've even set default credentials.
// The shared secret is a unique string shared between the payment terminal and your application, it is a free field.
// The Api key is a unique key per merchant used to authenticate the terminal against the Cloud.
// You should replace the API key with the one sent by the Handpoint support team.
// Now we need to find our device and connect to it.
discoverDevices();
}
// Now we need to connect to a device to start taking payments.
// Let's search for them:
public void discoverDevices(){
this.api.searchDevices(ConnectionMethod.CLOUD);
// This triggers the asynchronous search for all the devices around that haven't been paired.
// You could, alternatively, search for the already paired devices
// List<Device> devices = this.api.getPairedDevices(ConnectionMethod.CLOUD);
// Now:
// selectDeviceAndConnect(devices);
// You'll receive the devices found through the deviceDiscoveryFinished method.
// See: https://handpoint.com/docs/device/Android/#elem_eventsDeviceDiscoveryFinished
}
@Override
public void deviceDiscoveryFinished(List<Device> devices) {
selectDeviceAndConnect(devices);
}
private void selectDeviceAndConnect(List<Device> devices) {
for (Device device : devices) {
if (device.getName() != null){
// All the devices here are all of the merchant's devices
if (/* Fill your logic here */) {
this.api.connect(device);
// Now take a look at connectionStatusChanged method
break;
}
}
}
}
//Potentially, if you know the Serial number and model of the device you want to connect to, you can skip the search and do it this way
public void connect(){
Device device = new Device("CloudDevice", "9822032398-PAXA920", "", ConnectionMethod.CLOUD);
//new Device("name", "address", "port", ConnectionMethod.CLOUD);
this.api.connect(device);
}
@Override
public void connectionStatusChanged(ConnectionStatus status, Device device) {
if (status == ConnectionStatus.Connected) {
// Connected to device
}
}
public boolean pay() {
return this.api.sale(new BigInteger("1000"), Currency.GBP);
// Let´s start our first payment of 10 pounds
}
public boolean payWithOptions() {
SaleOptions options = new SaleOptions();
// Adding tipping
TipConfiguration config = new TipConfiguration();
//Optionally
config.setHeaderName("HEADER");
//Optionally
config.setFooter("FOOTER");
//Optionally
config.setEnterAmountEnabled(true);
//Optionally
config.setSkipEnabled(true);
//Optionally
config.setTipPercentages(Arrays.asList(5, 10, 15, 20));
options.setTipConfiguration(config);
// Adding Multi MID / Custom merchant Authentication
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(Acquirer.SANDBOX);
//Optionally
credential.setMid("mid");
//Optionally
credential.setTid("tid");
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
options.setMerchantAuth(auth);
//Add a customer reference
options.setCustomerReference("Your customer reference");
//Enable pin bypass
options.setPinBypass(true);
//Enable signature bypass
options.setSignatureBypass(true);
//Define a budget number
options.setBudgetNumber("YOUR_BUDGET_NUMBER");
return this.api.sale(new BigInteger("1000"),Currency.GBP, options);
}
@Override
public void currentTransactionStatus(StatusInfo statusInfo, Device device) {
if (statusInfo.getStatus() == StatusInfo.Status.InitialisationComplete) {
// The StatusInfo object holds the different transaction statuses like reading card, pin entry, etc.
// Let's launch a payment
pay();
}
}
@Override
public void signatureRequired(SignatureRequest signatureRequest, Device device) {
// This event can be safely ignored for a PAX/Telpo integration. The complete signature capture process
// is already handled in the sdk, a dialog will prompt the user for a signature if required.
// If a signature was entered, it should be printed on the receipts.
//For Datecs integrations:
// You'll be notified here if a sale process needs a signature verification
// A signature verification is needed if the cardholder uses an MSR or a chip & signature card
// This method will not be invoked if a transaction is made with a Chip & PIN card
// At this step, you are supposed to display the merchant receipt to the cardholder on the android device
// The cardholder must have the possibility to accept or decline the transaction
// If the cardholder clicks on decline, the transaction is VOID
// If the cardholder clicks on accept he is then asked to sign electronically the receipt
this.api.signatureResult(true);
// This line means that the cardholder ALWAYS accepts to sign the receipt
// For this sample app we are not going to implement the whole signature process
}
@Override
public void endOfTransaction(TransactionResult transactionResult, Device device) {
// The object TransactionResult stores the different receipts
// Other information can be accessed through this object like the transaction ID, the amount...
}
@Override
public void transactionResultReady(TransactionResult transactionResult, Device device) {
// Pending TransactionResult objects will be received through this event if the EndOfTransaction
// event was not delivered during the transaction, for example because of a network issue.
// For this sample app we are not going to implement this event.
}
public void disconnect(){
this.api.disconnect();
//This disconnects the connection
}
}
Sort of. With the above tutorial you've done a basic integration that can perform sale transactions.
Explore the rest of the documentation to see more transaction types supported and possibilities.
moToRefund
A MOTO refund operation moves funds from the merchant account to the cardholder´s credit card. In it's simplest form you only have to pass the amount and currency but it also accepts the original transaction id. MOTO Refund is a type of card-not-present (CNP) transaction in which services are refunded via telephone, mail, fax, or internet communication. MOTO has become synonymous with any financial transaction where the entity taking payment does not physically see the card used to make the purchase or refund.
Parameter | Notes |
---|---|
amount *
BigInteger |
Amount of funds to charge - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the charge |
originalTransactionId
String |
If present it links the refund with a previous sale. It effectively limits the maximum amount refunded to that of the original transaction. |
options
MoToOptions |
An object to store optional parameters for a MoTo refund. |
MoToOptions options = new MoToOptions();
options.setCustomerReference("MoTo Refund Example");
api.motoRefund(new BigInteger("1000"), Currency.EUR, "00000000-0000-0000-0000-000000000000",options);
moToReversal
A MOTO reversal, also called VOID allows the user to reverse a previous sale/refund operation. This operation reverts (if possible) a specific operation identified with a transaction id. Note that transactions can only be reversed within a 24 hours timeframe or until the daily batch of transactions has been sent for submission. MOTO Reversal is a type of card-not-present (CNP) transaction used to reverse a previous MOTO Sale or MOTO Refund.
Parameter | Notes |
---|---|
originalTransactionID *
String |
Id of the original sale transaction |
options
MoToOptions |
An object to store optional parameters for a MoTo reversal. |
MoToOptions options = new MoToOptions();
options.setCustomerReference("MoTo Reversal Example");
api.motoReversal("00000000-0000-0000-0000-000000000000",options);
moToSale
Mail Order /Telephone Order (MOTO) sale. MOTO is a type of card-not-present (CNP) transaction in which services are paid and delivered via telephone, mail, fax, or internet communication. MOTO has become synonymous with any financial transaction where the entity taking payment does not physically see the card used to make the purchase.
Parameter | Notes |
---|---|
amount *
BigInteger |
Amount of funds to charge - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the charge |
options
MoToOptions |
An object to store optional parameters for a MoTo sale. |
MoToOptions options = new MoToOptions();
options.setCustomerReference("MoTo Sale Example");
api.motoSale(new BigInteger("1000"), Currency.EUR, options);
saleAndTokenizeCard
A sale operation which also returns a card token. (not available for all acquirers, please check with Handpoint to know if tokenization is supported for your acquirer of choice)
Parameter | Notes |
---|---|
amount *
BigInteger |
Amount of funds to charge - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the charge |
options
SaleOptions |
An object to store all the customization options for a sale. |
//Initiate a sale for 10.00 in Great British Pounds
api.saleAndTokenizeCard(new BigInteger("1000"),Currency.GBP);
//Initiate a sale for 10.00 in Great British Pounds with tipping configuration
//This feature is not available for HiLite & Hi5 devices
TipConfiguration tipConfiguration = new TipConfiguration();
tipConfiguration.setTipPercentages(Arrays.asList(5, 10, 15, 20));
tipConfiguration.setAmount(new BigInteger("1000"));
tipConfiguration.setBaseAmount(new BigInteger("1000"));
tipConfiguration.setEnterAmountEnabled(true);
tipConfiguration.setFooter("Thank you");
tipConfiguration.setSkipEnabled(true);
SaleOptions options = new SaleOptions();
options.setTipConfiguration(tipConfiguration);
api.saleAndTokenizeCard(new BigInteger("1000"),Currency.GBP,options);
sale
A sale initiates a payment operation to the card reader. In it's simplest form you only have to pass the amount and currency but it also accepts tip configuration and a map with extra parameters.
Parameter | Notes |
---|---|
amount *
BigInteger |
Amount of funds to charge - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the charge |
options
SaleOptions |
An object to store all the customization options for a sale. |
//Initiate a sale for 10.00 in Great British Pounds
api.sale(new BigInteger("1000"),Currency.GBP);
//Initiate a sale for 10.00 in Great British Pounds with tipping configuration
//This feature is only available for PAX and Telpo devices
TipConfiguration tipConfiguration = new TipConfiguration();
tipConfiguration.setTipPercentages(Arrays.asList(5, 10, 15, 20));
tipConfiguration.setAmount(new BigInteger("1000"));
tipConfiguration.setBaseAmount(new BigInteger("1000"));
tipConfiguration.setEnterAmountEnabled(true);
tipConfiguration.setFooter("Thank you");
tipConfiguration.setSkipEnabled(true);
SaleOptions options = new SaleOptions();
options.setTipConfiguration(tipConfiguration);
api.sale(new BigInteger("1000"),Currency.GBP, options);
saleReversal
A sale reversal, also called sale VOID allows the user to reverse a previous sale operation. This operation reverts (if possible) a specific sale identified with a transaction id. In its simplest form you only have to pass the amount, currency and originalTransactionID but it also accepts a map with extra parameters. Note that transactions can only be reversed within a 24 hours timeframe or until the daily batch of transactions has been sent for submission.
Parameter | Notes |
---|---|
amount *
BigInteger |
Amount of funds to charge - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the charge |
originalTransactionID *
String |
Id of the original sale transaction |
options
MerchantAuthOptions |
An object to store all the customization options for the transaction. |
//Initiate a reversal for 10.00 in Great British Pounds
api.saleReversal(new BigInteger("1000"),Currency.GBP,"00000000-0000-0000-0000-000000000000");
refund
A refund operation moves funds from the merchant account to the cardholder´s credit card. In it's simplest form you only have to pass the amount and currency but it also accepts a map with extra parameters. Note that a card is required to be swiped, dipped or tapped for this operation. For Interac (Canadian Debit Network), refunds can only be processed until Interac closes the batch of transactions at night.
Parameter | Notes |
---|---|
amount *
BigInteger |
Amount of funds to charge - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the charge |
originalTransactionId
String |
If present it links the refund with a previous sale. It effectively limits the maximum amount refunded to that of the original transaction. |
options
RefundOptions |
An object to store all the customization options for a refund. |
//Initiate a refund for 10.00 in Great British Pounds
api.refund(new BigInteger("1000"),Currency.GBP,"00000000-0000-0000-0000-000000000000");
refundReversal
A refund reversal, also called refund VOID allows the merchant to reverse a previous refund operation. This operation reverts (if possible) a specific refund identified with a transaction id. In it's simplest form you only have to pass the amount, currency and originalTransactionID but it also accepts a map with extra parameters. Note that transactions can only be reversed within a 24 hours timeframe or until the daily batch of transactions has been sent for submission.
Parameter | Notes |
---|---|
amount *
BigInteger |
Amount of funds to charge - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the charge |
originalTransactionID *
String |
transaction id of the original refund |
options
MerchantAuthOptions |
An object to store all the customization options for the transaction. |
//Initiate a refund reversal for 10.00 in Great British Pounds
api.refundReversal(new BigInteger("1000"),Currency.GBP,"00000000-0000-0000-0000-000000000000");
signatureResult
A signatureRequired event is invoked during a transaction when a signature verification is required (f.ex when a payment is done with a swiped or chip and sign card). The merchant is required to ask the cardholder for signature and approve (or decline) the signature. signatureResult tells the card reader if the signature was approved by passing the value true in the method. To decline a signature event then false should be passed to the card reader. Note that this event is only required for an HiLite or Hi5 integration and can be safely ignored for a PAX or Telpo integration.
Parameter | Notes |
---|---|
accepted *
Boolean |
pass true if merchant accepts cardholder signature |
//Approves signature automatically in signatureRequired event
@Override
public void signatureRequired(SignatureRequest signatureRequest, Device device){
api.signatureResult(true);
}
TipAdjustment
A tip adjustment operation allows merchants to adjust the tip amount of a sale transaction before the batch of transactions is settled by the processor at the end of the day.
Note: This functionality is only available for the restaurant industry in the United States and the processors currently supporting this functionality are TSYS and VANTIV.
Dependencies:
The code example provided depends on RxJava, take a look a their documentation to see how to easily include this dependency in your android project. If you do not want to use RxJava or any additional dependencies then AsyncTask, provided by android, can be used instead for this asynchronous processing. Still we recommend using RxJava as it improves readability and maintainability.
Parameter | Notes |
---|---|
tipAmount *
BigDecimal |
Tip amount added to the original (base) transaction amount - in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
originalTransactionID *
String |
Unique id of the original sale transaction as received from the card reader (EFTTransactionID) |
Observable.fromCallable(new Callable() {
@Override
public FinancialStatus call() throws Exception {
return api.tipAdjustment(new BigDecimal(1000), "2bc23910-c3b3-11e6-9e62-07b2a5f091ec");
}
})
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Consumer() {
@Override
public void accept(@NonNull FinancialStatus status) throws Exception {
if (status == FinancialStatus.AUTHORISED) {
//SUCCESS
} else if (status == FinancialStatus.DECLINED) {
//DECLINED
} else {
//FAILED
}
});
tokenizeCard
Returns a card token (not available for all acquirers, please check with Handpoint to know if tokenization is supported for your acquirer of choice)
Parameter | Notes |
---|---|
options
Options |
An object to store all the customization options for the transaction. |
//Tokenize a card
api.tokenizeCard();
cardPan
A cardPan request will return the full PAN of the card being swiped, dipped or tapped. Only the PANs of whitelisted card ranges will be returned by the Handpoint systems. This operation is mostly used to be able to process funds or points from loyalty cards.
Parameter | Notes |
---|---|
options
Options |
An object to store all the customization options for the transaction. |
//Gets the PAN of a card
api.cardPan();
connect
Connects to a device. Whenever the connection to the device is lost, the SDK will keep on trying to establish a connection until it’s re-established. No special actions are needed.
Parameter | Notes |
---|---|
device *
Device |
This parameter specifies which device type you want to connect to. |
//Connect to a device
Device device = new Device("CardReader7", "08:00:69:02:01:FC", "1", ConnectionMethod.BLUETOOTH);
Device device = new Device("LocalDevice", "0821032398-PAXA920", "", ConnectionMethod.ANDROID_PAYMENT);
Device device = new Device("CloudDevice", "0821032398-PAXA920", "", ConnectionMethod.CLOUD);
api.connect(device);
getTransactionsReport
Fetches your transactions report from a device/devices. If you want to print the report, you can call printReceipt with the string returned in ReportResult event as parameter.
Parameter | Notes |
---|---|
reportConfiguration *
ReportConfiguration |
This parameter specifies the filter to get transactions report. |
//Get the transactions report for device "12345", from 30th April 2021 at 00:00:00, to 30th April 2021 at 23:59:59, in eurs:
List terminalSerialNumber = new ArrayList<>();
terminalSerialNumber.add("12345");
ReportConfiguration configuration = new ReportConfiguration("EUR", "20210430000000", "20210430235959", terminalSerialNumber);
api.getTransactionsReport(configuration);
disconnect
Disconnect will stop the active connection (or reconnection process). Please note that the method ignores the current state of the terminal and just stops the connection. Calling disconnect might result in a commmunication error if triggered during a transaction.
//Disconnect from current device
api.Disconnect();
getEMVConfiguration
Fetches the logs from the device and reports them to the deviceLogsReady event.
//Downloads logs from device
api.getDeviceLogs();
getPairedDevices
Returns the payment terminals associated with the specified ConnectionMethod
Parameter | Notes |
---|---|
method *
ConnectionMethod |
The type of connection with the payment terminal (Bluetooth, Cloud, etc.). |
// Get paired terminals
List<Device> devices = api.getPairedDevices(ConnectionMethod.XXX);
getDeviceLogs
Fetches the logs from the device and reports them to the deviceLogsReady event.
//Downloads logs from device
api.getDeviceLogs();
getDeviceManufacturer
Returns the manufacturer of the payment terminal
Manufacturer manufacturer = api.getDeviceManufacturer();
deleteDeviceConfig
Sends a command to the terminal to delete its configuration
api.deleteDeviceConfig();
printReceipt
Print on demand functionality allowing the merchant to print any HTML formatted receipt. It is possible to print images or barcodes. A bitmap can also be printed, in order to do so it needs to be rendered as an image and inserted into the html.
Parameter | Notes |
---|---|
receipt *
String |
The receipt must match the following HTML Print Format. The Transaction Report (also called End of Day Report) can be printed from the string returned in the ReportResult event. |
//Print a receipt with Handpoint logo (bitmap format)
String validReceipt = "<html><body><img src=''></body></html>";
boolean success = api.printReceipt(validReceipt);
searchDevices
Starts the search of payment terminals associated with the specified ConnectionMethod
Parameter | Notes |
---|---|
method *
ConnectionMethod |
The type of connection with the payment terminal (Bluetooth, Cloud, etc.). |
// Starts the search for payment terminals.
// You must implement Events.DeviceDiscoveryFinished and subscribe
// to the event delegate in order to receive the result
api.searchDevices(ConnectionMethod.XXX);
setLocale
Sets the SDK Locale (language). It is used to set the SDK language as well as the associated date and number formatting.
Parameter | Notes |
---|---|
locale *
SupportedLocales |
The locale to be set. Supported locales are: SupportedLocales.en_CA, SupportedLocales.en_UK, SupportedLocales.en_US, SupportedLocales.hr_HR, SupportedLocales.is_IS, SupportedLocales.fr_FR, SupportedLocales.pt_PT. |
// Set canadian english
api.setLocale(SupportedLocales.en_CA);
setLogLevel
Sets the log level (info, debug...) for both the payment terminal and the SDK.
Parameter | Notes |
---|---|
level *
LogLevel |
The desired log level. Can be LogLevel.None, LogLevel.Info, LogLevel.Full, LogLevel.Debug |
device
Device |
This parameter specifies to the system which device should be used for the operations. If no device is supplied, the system will attempt to use a default one. |
//Sets the log level to info
api.setLogLevel(LogLevel.info);
stopCurrentTransaction
Stops the current transaction. A transaction can be stopped only if the last currentTransactionStatus event reported has the property isCancelAllowed set to true.
NOTE: this operation is Not supported on Datecs devices.
// Stops current transaction
if (api.stopCurrentTransaction()) {
...
} else {
...
}
update
The update operation checks for new software or configuration updates and initiates a download if required.
Parameter | Notes |
---|---|
device
Device |
This parameter specifies to the system which device should be used for the operations. If no device is supplied, the system will attempt to use a default one. |
//Check for card reader update
api.update();
registerEventsDelegate
Registers a delegate for the SDK events.
Parameter | Notes |
---|---|
listener *
Object |
Any Object implementing one or more of the available delegate interfaces. |
public class ObjectHelper implements Events.Required, Events.Status, Events.Log, Events.PendingResults, Events.TransactionStarted {
...
private void setEventsHandler() {
// Register this class as listener for events
this.api.registerEventsDelegate(this);
...
}
}
unregisterEventsDelegate
Unregisters an object from SDK events.
Parameter | Notes |
---|---|
listener *
Object |
Any Object implementing one or more of the available delegate interfaces. |
public class ObjectHelper implements Events.Required, Events.Status, Events.Log, Events.PendingResults, Events.TransactionStarted {
...
private void unsubscribeEventsDelegate() {
// Stop receiving events
this.api.unregisterEventsDelegate(this);
...
}
Events.All
An interface which needs to be implemented and added as a listener to receive all available events.
Required
Log
Status
PendingResults
ReportResult
PrinterEvents
TransactionStarted
MessageHandling
PhysicalKeyboardEvent
CardBrandDisplay
Events.Basic
An interface which needs to be implemented and added as a listener to receive basic events.
Required
Log
Status
PendingResults
ReportResult
Events.ConnectionStatusChanged
Implement this interface in order to receive connection status changes.
connectionStatusChanged( ConnectionStatus status , Device device );
Parameter | Notes |
---|---|
status *
ConnectionStatus |
New status of the connection |
device *
Device |
The terminal which sent this information. |
public final class EventHandler implements Events.ConnectionStatusChanged {
@Override
public void connectionStatusChanged(ConnectionStatus status, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.CurrentTransactionStatus
Implement this interface in order to receive events about the current transaction.
currentTransactionStatus( StatusInfo status , Device device );
Parameter | Notes |
---|---|
status *
StatusInfo |
The StatusInfo of the current transaction |
device *
Device |
The terminal the request is sent from. |
public final class EventHandler implements Events.CurrentTransactionStatus {
@Override
public void currentTransactionStatus(StatusInfo info, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.DeviceCapabilitiesReady
Implement this interface in case the terminal needs to notify the SDK of its capabilities
deviceCapabilities( DeviceCapabilities capabilities , Device device );
Parameter | Notes |
---|---|
capabilities *
DeviceCapabilities |
The capabilities of the terminal |
device *
Device |
The terminal sending its capabilities |
public final class EventHandler implements Events.DeviceCapabilitiesReady {
@Override
public void deviceCapabilities(DeviceCapabilities capabilities, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.DeviceDiscoveryFinished
Implement this interface in order to receive a list of available terminals. The event handler defined in this interface is invoked after calling the method searchDevices
deviceDiscoveryFinished( List<Device> devices );
Parameter | Notes |
---|---|
devices *
List<Device> |
A list of available devices. |
public final class EventHandler implements Events.DeviceDiscoveryFinished {
@Override
public void deviceDiscoveryFinished(List<Device> devices) {
// Receiving a list of connectable devices
foreach(Device device in devices) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.EndOfTransaction
Implement this interface to receive an event when a transaction is complete.
endOfTransaction( TransactionResult result , Device device );
Parameter | Notes |
---|---|
result *
TransactionResult |
Holds all the information about the transaction. |
device *
Device |
The payment terminal. |
public final class EventHandler implements Events.EndOfTransaction {
@Override
public void endOfTransaction(TransactionResult result, Device device) {
// Check the status of the transaction, save it, ...
}
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.HardwareStatusChanged
Implement this interface in order to receive events when the hardware status changes.
hardwareStatusChanged( HardwareStatus status , Device device );
Parameter | Notes |
---|---|
status *
HardwareStatus |
New status of the hardware. |
device *
Device |
The payment terminal. |
public final class EventHandler implements Events.HardwareStatusChanged {
@Override
public void hardwareStatusChanged(HardwareStatus status, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.Log
An interface which needs to be implemented and added as a listener to receive logging information.
OnMessageLogged
public final class EventHandler implements Events.Log {
@Override
public void deviceLogsReady(String logs, Device device) { ... }
@Override
public void onMessageLogged(LogLevel level , String message) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.MessageHandling
An interface which needs to be implemented and added as a listener to get events which are called when the sdk asks the application to display or hide a message.
showMessage( String message , Boolean dismissible , int duration );
Parameter | Notes |
---|---|
message *
String |
Message to display |
dismissible *
Boolean |
A flag that indicates whether the message can be dismissed |
duration *
int |
The timeout to hide the message. In milliseconds, if 0 is sent, the message should not auto dismiss. |
hideMessage( String message );
Parameter | Notes |
---|---|
message *
String |
Message to hide |
public final class EventHandler implements Events.MessageHandling {
@Override
public void showMessage(String message, Boolean dismissible, int duration) {
// Show message for a 'duration' period (if duration = 0 DO NOT dismiss until hideMessage(String message) event is received) and make it dismissible if the input marks it as possible
}
@Override
public void hideMessage(String message) {
// Hide the message
}
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.CardBrandDisplay
An interface which needs to be implemented and added as a listener to get events providing information on the supported card brands and/or the card brand used during the transaction.
deviceCapabilities(
List
Parameter | Notes |
---|---|
supportedCardBrands *
List |
A list containing the supported card brands |
readCard( CardBrands usedCard );
Parameter | Notes |
---|---|
usedCard *
CardBrands |
Name of the card brand |
public final class EventHandler implements Events.CardBrandDisplay {
@Override
public void deviceCapabilities(List extends CardBrands> supportedCardBrands) {
// Get supported card brands
}
@Override
public void readCard(CardBrands usedCard) {
// Get the used card brand
}
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.OnMessageLogged
Implement this interface to receive logs from the payment terminal. You must call getDeviceLogs
to request the logs.
onMessageLogged( LogLevel level , String message );
Parameter | Notes |
---|---|
level *
LogLevel |
The LogLevel of the logging |
message *
String |
The log trace which was logged by the SDK. |
public final class EventHandler implements Events.OnMessageLogged {
@Override
public void onMessageLogged(LogLevel level, String message) {
// Process log trace
}
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.PaymentProvider
An interface which needs to be implemented and added as a listener to receive all available events related to financial operations.
SignatureRequired
EndOfTransaction
OnMessageLogged
CurrentTransactionStatus
Events.PendingResults
An interface which needs to be implemented and added as a listener to receive information about pending TransactionResults. In case of a communication failure between the SDK and the payment terminal there might be a result pending from the transaction which did not get sent to the SDK.
TransactionResultReady
public final class EventHandler implements Events.PendingResults {
@Override
public void transactionResultReady(TransactionResult transactionResult, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.PrinterEvents
An interface which needs to be implemented and added as a listener to get events coming from the printer.
printSuccess( );
Parameter | Notes |
---|---|
|
printError( PrintError error );
Parameter | Notes |
---|---|
error *
PrintError |
Enum detailing the reason of the error |
public final class EventHandler implements Events.PrinterEvents {
@Override
public void printSuccess() {
// Successful print action
}
@Override
public void printError(PrintError error) {
// Unable to perform print action due to error
}
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.ReportResult
Implement this interface to receive an event when a report result from a getTransactionsReport is returned
reportResult( TypeOfResult type , String report , DeviceStatus status , Device device );
Parameter | Notes |
---|---|
type *
TypeOfResult |
The type of the report |
report *
String |
The text of the report |
status *
DeviceStatus |
The status of the device |
device *
Device |
The terminal sending the report |
public final class EventHandler implements Events.ReportResult {
@Override
public void reportResult(TypeOfResult type, String report, DeviceStatus status, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.Required
You must provide a class implementing this interface when initializing the SDK.
SignatureRequired
EndOfTransaction
DeviceDiscoveryFinished
PendingResults
public final class EventHandler implements Events.Required {
@Override
public void signatureRequired(SignatureRequest signatureRequest, Device device) { ... }
@Override
public void endOfTransaction(TransactionResult transactionResult, Device device) { ... }
@Override
public void deviceDiscoveryFinished(List devices) { ... }
@Override
public void transactionResultReady(TransactionResult transactionResult, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.SignatureRequired
The SignatureRequired interface must be implemented in order to receive an event when a card requires a signature as a verification method. This interface is only required for an Hi5 or Hilite integration, PAX and Telpo terminals automatically prompt for signature capture on the terminal.
signatureRequired( SignatureRequest request , Device device );
Parameter | Notes |
---|---|
request *
SignatureRequest |
Holds the signature request. |
device *
Device |
The payment terminal. |
public final class EventHandler implements Events.SignatureRequired {
@Override
public void signatureRequired(SignatureRequest signatureRequest, Device device) {
// Save merchant receipt
String merchantReceipt = signatureRequest.getMerchantReceipt();
api.signatureResult(true);
}
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.Status
An interface which needs to be implemented and added as a listener to receive connection and transaction statuses.
ConnectionStatusChanged
HardwareStatusChanged
CurrentTransactionStatus
public final class EventHandler implements Events.Status {
@Override
public void connectionStatusChanged(ConnectionStatus status, Device device) { ... }
@Override
public void hardwareStatusChanged(HardwareStatus status, Device device) { ... }
@Override
public void currentTransactionStatus(StatusInfo info, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.TransactionResultReady
Implement this interface in order to receive an event after a pending TransactionResult has been recovered from the payment terminal.
transactionResultReady( TransactionResult transactionResult , Device device );
Parameter | Notes |
---|---|
transactionResult *
TransactionResult |
A TransactionResult is containing all information about the recovered transaction. |
device *
Device |
The payment terminal. |
public final class EventHandler implements Events.TransactionResultReady {
@Override
public void transactionResultReady(TransactionResult transactionResult, Device device) { ... }
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
Events.TransactionStarted
Implement this interface in order to receive an event when a transaction is started through the Cloud API channel.
IMPORTANT NOTE: This interface is only available for cloud-enabled devices. See DeviceCapabilitiesReady interface.
transactionStarted( TransactionType transactionType , BigInteger amount , Currency currency );
Parameter | Notes |
---|---|
transactionType *
TransactionType |
Type of transaction started |
amount *
BigInteger |
Amount in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
currency *
Currency |
Currency of the transaction started |
public final class EventHandler implements Events.TransactionStarted {
@Override
public void transactionStarted(TransactionType type, BigInteger amount, Currency currency) {
// Notify the app user transaction has been started ...
}
}
// Remember to register the instance of this EventHandler:
this.api.registerEventsDelegate(eventHandlerInstance);
TransactionResult
An object holding information about the result of a transaction.
Property | Description |
---|---|
aid String |
Application Identifier of the card (EMV tag 9F06) |
arc String |
EMV Authorisation Response Code (EMV tag 8A) |
authorisationCode String |
Acquirer response code |
balance Balance |
Balance available on the card |
budgetNumber String |
Used to split payments over a period of months |
cardEntryType CardEntryType |
Method used by the terminal to read the card |
cardLanguagePreference String |
Preferred language of the card (EMV tag 5F2D) |
cardSchemeName CardSchemeName |
The brand of the card |
cardToken String |
Token representing the PAN of the card |
chipTransactionReport String |
Full report of the card EMV parameters |
currency Currency |
The currency used for the transaction |
customerReceipt String |
A URL containing the customer receipt in HTML format |
customerReference String |
If a customerReference was provided as an optional parameter in the transaction request it is echoed unaltered in this field |
deviceStatus DeviceStatus |
Status of the device |
dueAmount String |
In case of a partial approval for the transaction, this field contains the amount which remains to be paid |
efttimestamp Date |
Time of the transaction |
efttransactionID String |
Handpoint unique identifier for a transaction, this id is the one to be used for a transaction to be reversed. |
errorMessage String |
Detailed reason for the transaction error |
expiryDateMMYY String |
Expiry date of the card used for the operation |
finStatus FinancialStatus |
The financial status contains the outcome of the transaction. For example "AUTHORISED" or "DECLINED" |
iad String |
Issuer Application Data (EMV tag 9F10) |
issuerResponseCode String |
Response code from the card issuer |
maskedCardNumber String |
Masked card number of the card used for the operation |
merchantAddress String |
Merchant Address |
merchantName String |
Merchant Name |
merchantReceipt String |
A URL containing the customer receipt in HTML format |
mid String |
Merchant Identifier |
originalEFTTransactionID String |
In case the transaction type is a reversal, this field will contain the identifier of the original transaction being reversed |
paymentScenario PaymentScenario |
Indicates the card entry mode |
recoveredTransaction boolean |
This flag is set to true if the transaction result is sent through the transaction recovery logic explained in the Recovey Section, false otherwise |
requestedAmount BigInteger |
The requested amount is the transaction amount sent to the terminal |
rrn String |
Retrieval Reference Number, unique number assigned by the acquirer |
signatureUrl String |
If a digital signature is required, this is the URL containing the image of the captured signature |
statusMessage String |
The status of the transaction, for example "Waiting for pin" |
tenderType TenderType |
Transaction tender type (credit / debit) |
tid String |
Terminal Identifier |
tipAmount BigInteger |
Tip amount, if any, in the minor unit of currency (f.ex. 1000 is 10.00 GBP) |
tipPercentage double |
If tipping is enabled, this field will return the tip percentage added on top of the base amount |
totalAmount BigInteger |
The total amount is the amount the card was charged for. It is possible that the total amount is not the same as the requested amount since an additional fee can be added, with the customer's approval, via the tipping functionality |
transactionID String |
The transaction id is a terminal internal counter incremented for each transaction |
tsi String |
Transaction Status Information (EMV tag 9B) |
tvr String |
Transaction Verification Results (EMV tag 95) |
type TransactionType |
The type of transaction initiated, for example "SALE" |
unMaskedPan String |
Unmasked PAN, only received if the card is a non-payment card (loyalty) |
verificationMethod VerificationMethod |
cardholder verification method, for example "PIN" |
multiLanguageStatusMessages Map |
map containing the status message in a human readable format for all the supported locales. |
multiLanguageErrorMessages Map |
map containing the error message in a human readable format for all the supported locales. |
cardHolderName String |
Name of the cardholder |
{
"aid": "A0000000041010",
"arc": "0000",
"authorisationCode": "123456",
"balance": null,
"budgetNumber": "",
"cardEntryType": "UNDEFINED",
"cardLanguagePreference": "",
"cardSchemeName": "MasterCard",
"cardToken": "",
"chipTransactionReport": "",
"currency": "USD",
"customerReceipt": "https://s3.[...]/customerReceipt.html",
"customerReference": "",
"deviceStatus": {
"applicationName": "ClientApp",
"applicationVersion": "20.1.0",
"batteryCharging": "Not Charging",
"batteryStatus": "100",
"batterymV": "4126",
"bluetoothName": "PAXA920",
"externalPower": "USB",
"serialNumber": "0821032398",
"statusMessage": "Approved or completed successfully"
},
"dueAmount": 0,
"errorMessage": "",
"expiryDateMMYY": "0422",
"finStatus": "AUTHORISED",
"iad": "0210A000002A0000000000000000000000FF",
"issuerResponseCode": "00",
"maskedCardNumber": "************1456",
"merchantAddress": "Plaza Soledad Torres Acosta 1 28013 Madrid",
"merchantName": "Hago la cama",
"merchantReceipt": "https://s3.[...]/merchantReceipt.html",
"mid": "",
"originalEFTTransactionID": "",
"paymentScenario": "CHIPCONTACTLESS",
"rrn": "",
"signatureUrl": "",
"statusMessage": "Approved or completed successfully",
"tenderType": "CREDIT",
"tid": "ACQUIRER_TID",
"tipAmount": 0,
"totalAmount": 100,
"transactionID": "01236fc0-8192-11eb-9aca-ad4b0e95f241",
"tsi": "0000",
"tvr": "0400008001",
"type": "SALE",
"unMaskedPan": "",
"verificationMethod": "UNDEFINED",
"efttimestamp": 1615374961000,
"efttransactionID": "01236fc0-8192-11eb-9aca-ad4b0e95f241",
"requestedAmount": 100,
"tipPercentage": 0,
"recoveredTransaction": false,
"multiLanguageStatusMessages": [
{ "en_US" : "Approved or completed successfully" },
{ "fr_FR" : "Transaction approuvée" }
],
"multiLanguageErrorMessages": [],
"cardHolderName": "cardholder name"
}
MoToOptions
An object to store optional parameters for card not present MoTo transactions.
Property | Description |
---|---|
CustomerReference String |
An arbitrary string to use as your own identifier for a transaction |
Channel MoToChannel |
MO for Mail order - TO for Telephone order |
Tokenize Boolean |
Flag to activate tokenization of the operation, if this flag is set, a token representing the PAN of the card will be sent back by the Handpoint sytems |
MoToOptions options = new MoToOptions();
options.setCustomerReference("Trx3245");
options.setTokenize(true);
options.setTokenize(false);
options.setChannel(MoToChannel.MO);
options.setChannel(MoToChannel.TO);
Acquirer
An enum representing all the supported acquirers for merchant authentication
AMEX
BORGUN
EVO
OMNIPAY
POSTBRIDGE
INTERAC
TSYS
VANTIV
SANDBOX
public enum Acquirer { AMEX,
BORGUN,
EVO,
OMNIPAY,
POSTBRIDGE,
INTERAC,
TSYS,
VANTIV,
SANDBOX
}
CardEntryType
An enum representing different card entry types.
UNDEFINED
MSR
ICC
CNP
ConnectionMethod
An enum representing different connection methods with the payment terminal.
Currently BLUETOOTH
, SIMULATOR
, CLOUD
and ANDROID_PAYMENT
are supported types.
USB
SERIAL
BLUETOOTH
CLOUD
ANDROID_PAYMENT
HTTPS
WIFI
ETHERNET
SIMULATOR
//Currently BLUETOOTH, SIMULATOR, CLOUD and ANDROID_PAYMENT are the only ConnectionMethod available.
public enum ConnectionMethod {
USB,
SERIAL,
BLUETOOTH,
HTTPS,
WIFI,
ETHERNET,
SIMULATOR,
CLOUD,
ANDROID_PAYMENT
}
ConnectionStatus
A list of connection statuses. Note: the events starting with Cloud[...] are exclusively for devices linked to merchants with CLOUD Api key (CLOUD mode enable).
Connected
Connecting
Disconnected
Disconnecting
NotConfigured
Initializing
CloudConnected
CloudInitialized
CloudAvailable
CloudDisconnected
CloudUnavailable
Currency
An enum of currencies.
It contains the name of the currency, its ISO code, as well as information about how many decimals the currency uses.
AED
AFN
ALL
AMD
ANG
AOA
ARS
AUD
AWG
AZN
BAM
BBD
BDT
BGN
BHD
BIF
BMD
BND
BOB
BOV
BRL
BSD
BTN
BWP
BYR
BZD
CAD
CDF
CHF
CLP
CNY
COP
COU
CRC
CUC
CUP
CVE
CZK
DJF
DKK
DOP
DZD
EEK
EGP
ERN
ETB
EUR
FJD
FKP
GBP
GEL
GHS
GIP
GMD
GNF
GTQ
GYD
HKD
HNL
HRK
HTG
HUF
IDR
ILS
INR
IQD
IRR
ISK
JMD
JOD
JPY
KES
KGS
KHR
KMF
KPW
KRW
KWD
KYD
KZT
LAK
LBP
LKR
LRD
LSL
LTL
LVL
LYD
MAD
MDL
MKD
MMK
MNT
MOP
MUR
MVR
MWK
MXN
MXV
MYR
MZN
NAD
NGN
NIO
NOK
NPR
NZD
OMR
PAB
PEN
PGK
PHP
PKR
PLN
PYG
QAR
RON
RSD
RUB
RWF
SAR
SBD
SCR
SDG
SEK
SGD
SHP
SLL
SOS
SRD
STD
SYP
SZL
THB
TJS
TMT
TND
TOP
TRY
TTD
TWD
TZS
UAH
UGX
USD
UZS
VEF
VND
VUV
WST
XAF
XCD
XOF
XPF
YER
ZAR
ZMK
ZWL
MerchantAuth
An object to store merchant authentication.
MerchantAuth( );
MerchantAuth( Credential credential );
Parameter | Notes |
---|---|
credential
Credential |
If present, adds the given credential to the list. |
MerchantAuth( List<Credential> credentials );
Parameter | Notes |
---|---|
credentials
List<Credential> |
If present, the list of credentials. |
add( Credential credential );
Parameter | Notes |
---|---|
credential *
Credential |
The credential to be added. |
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential.setMerchantId(mid);
//Optionally
credential.setTerminalId(tid);
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
SaleOptions
An object to store all the customization options for a sale.
Property | Description |
---|---|
BudgetNumber String |
The budget number can be used to split payments over a period of months. |
CustomerReference String |
An arbitrary string to use as your own identifier for a transaction |
MerchantAuth MerchantAuth |
An object containing all the credentials used to optionally authenticate a merchant |
PinBypass Boolean |
Bypasses PIN entry when the shopper says they don't know the PIN for the card and the merchant either knows they are the legitimate cardholder or want to give them the benefit of the doubt. PIN Bypass should be set to True if you want to enable pin bypass for a transaction |
SignatureBypass Boolean |
Whether the terminal prompts for a signature, depends on how you configure this. The major card schemes (American Express, Diners, Discover, JCB, Mastercard, Visa, UnionPay) no longer require a signature; they regard it as optional for card-present transactions. This means you can speed up your checkout by skipping the signature prompt. But if your business requires it, you can still let the terminal prompt for a signature. The shopper then provides their signature on the touch screen of the terminal or on the printed transaction receipt. This depends on how you configure this setting. It is your responsibility to verify the signature of the shopper with the signature on the card or another form of identification. Signature Bypass should be set to True if you want to enable signature for this transaction |
TipConfiguration TipConfiguration |
An object containing the tip configuration for this transaction |
SaleOptions options = new SaleOptions();
//If you use a customer reference
options.setCustomerReference("Your customer reference");
//If you need Multi MID / Custom merchant Authentication
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential.setMerchantId(mid);
//Optionally
credential.setTerminalId(tid);
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
options.setMerchantAuth(auth);
//If you need to enable pin bypass
options.setPinBypass(true);
//If you want to specify the budget period
//Only available for SureSwipe
options.setBudgetNumber(YOUR_BUDGET_NUMBER);
//If you want to specify tip options
//Only available for PAX and Telpo terminals.
TipConfiguration config = new TipConfiguration();
//Optionally
config.setHeaderName(HEADER);
//Optionally
config.setFooter(FOOTER);
//Optionally
config.setEnterAmountEnabled(true);
//Optionally
config.setSkipEnabled(true);
config.setTipPercentages(percentages);
options.setTipConfiguration(config);
//Alternatively, you can set the tip amount directly
options.setTipConfiguration(new TipConfiguration(AMOUNT));
ReportConfiguration
An object to store all the configuration for a transactions report.
Property | Description |
---|---|
currency Currency |
The currency to filter the transactions |
startDate String |
The start date in format 'YYYYMMDDHHmmss. |
endDate String |
The end date in format 'YYYYMMDDHHmmss. |
terminalSerialNumber List |
The serial number of the terminal to fetch the transactions from (if terminalSerialNumber is empty or null, the report will show all the transactions for this merchant). |
ReportConfiguration configuration = new ReportConfiguration("'USD'", "'20210430000000'", "'20210430235959'", "null");
If you want to add terminal serial numbers: List terminalSerialNumber = new ArrayList<>();
terminalSerialNumber.add("0123456789");
terminalSerialNumber.add("9876543210");
... ;
RefundOptions
An object to store all the customization options for a refund.
Property | Description |
---|---|
CustomerReference String |
An arbitrary string to use as your own identifier for a transaction |
MerchantAuth MerchantAuth |
An object containing all the credentials used to optionally authenticate a merchant |
PinBypass Boolean |
Bypasses PIN entry when the shopper says they don't know the PIN for the card and the merchant either knows they are the legitimate cardholder or want to give them the benefit of the doubt. PIN Bypass should be set to True if you want to enable pin bypass for a transaction |
SignatureBypass Boolean |
Whether the terminal prompts for a signature, depends on how you configure this. The major card schemes (American Express, Diners, Discover, JCB, Mastercard, Visa, UnionPay) no longer require a signature; they regard it as optional for card-present transactions. This means you can speed up your checkout by skipping the signature prompt. But if your business requires it, you can still let the terminal prompt for a signature. The shopper then provides their signature on the touch screen of the terminal or on the printed transaction receipt. This depends on how you configure this setting. It is your responsibility to verify the signature of the shopper with the signature on the card or another form of identification. Signature Bypass should be set to True if you want to enable signature for this transaction |
RefundOptions options = new RefundOptions();
//If you use a customer reference
options.setCustomerReference("Your customer reference");
//If you need Multi MID / Custom merchant Authentication
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential.setMerchantId(mid);
//Optionally
credential.setTerminalId(tid);
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
options.setMerchantAuth(auth);
//If you need to enable pin bypass
options.setPinBypass(true);
Options
An object to store customer reference options for regular operations.
Property | Description |
---|---|
CustomerReference String |
An arbitrary string to use as your own identifier for a transaction |
Options options = new Options();
//If you use a customer reference
options.setCustomerReference("Your customer reference");
BalanceSign
An enum representing the balance sign
POSITIVE_SIGN('C')
NEGATIVE_SIGN('D')
MerchantAuthOptions
An object to store merchant authentication options for regular operations.
Property | Description |
---|---|
CustomerReference String |
An arbitrary string to use as your own identifier for a transaction |
MerchantAuth MerchantAuth |
An object containing all the credentials used to optionally authenticate a merchant |
MerchantAuthOptions options = new MerchantAuthOptions();
//If you use a customer reference
options.setCustomerReference("Your customer reference");
//If you need Multi MID / Custom merchant Authentication
MerchantAuth auth = new MerchantAuth();
Credential credential = new Credential();
//Optionally
credential.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential.setMerchantId(mid);
//Optionally
credential.setTerminalId(tid);
//Add as many credentials as Acquirers your merchant have agreements with
auth.add(credential);
options.setMerchantAuth(auth);
Device
An object to store the information about the payment terminal in use.
Device( String name , String address , String port , ConnectionMethod connectionMethod , String sharedSecret , int timeout );
Parameter | Notes |
---|---|
name *
String |
A name to identify the device |
address *
String |
The address of the device you wish to connect to. E.g.: "08:00:69:02:01:FC" for bluetooth, "9822032398-PAXA920" for CLOUD (composition of serial number and model of the target device) or just an identifier if your application is running directly on a PAX or Telpo device (ConnectionMethod.ANDROID_PAYMENT). |
port *
String |
The port to connect to (optional). |
connectionMethod *
ConnectionMethod |
Type of connection with the payment terminal. E.g: Bluetooth, Cloud, Serial, etc... |
sharedSecret
String |
Replaces the default shared secret proviced in the initialization step. |
timeout
int |
The number of miliseconds until a connection is considered timed out. If not set, the default timeout is 15 seconds. |
Property | Description |
---|---|
Id String |
A unique identifier for the payment terminal. |
//Create and init a new Datecs Device
Device dev = new Device("CardReader7", "08:00:69:02:01:FC", "1", ConnectionMethod.BLUETOOTH);
//Create and init a new PAX/Telpo Device for a CLOUD connection
Device dev = new Device("CloudDevice", "9822032398-PAXA920", "", ConnectionMethod.CLOUD);
// The address is the composition of the serial number and model ot the target device.
//Example for a PAX A920 device: serial_number - model -> 9822032398-PAXA920
//Create and init a new PAX/Telpo Device for a ANDROID_PAYMENT connection
Device dev = new Device("LocalPaxOrTelpo", "LocalHost", "", ConnectionMethod.ANDROID_PAYMENT);
Credential
An object to store credentials (Acquirer, Mid, Tid, MCC and ExternalId) for merchant authentication.
Property | Description |
---|---|
acquirer Acquirer |
If present, it links this credential to the specified acquirer. Required if more than one credential is provided. |
mid String |
For this transaction, overrides the default MID (merchant ID) saved in the terminal configuration. |
tid String |
For this transaction, overrides the default TID (terminal ID) saved in the terminal configuration. |
mcc String |
Merchant Category Code, overrides the default MCC saved in the terminal configuration. |
ExternalId String |
For this transaction, the External Id will be used to lookup the credential of the merchant in the Handpoint backend and process the transaction accordingly. The External id replaces the need to pass MID/TID/MCC as credentials |
// Credential using Acquirer, MID, TID and MCC
Credential credential1 = new Credential();
//Optionally
credential1.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential1.setMerchantId(mid);
//Optionally
credential1.setTerminalId(tid);
//Optionally
credential1.setMcc(mcc);
// Credential using ExternalId
Credential credential2 = new Credential();
credential2.setExternalId(externalId);
DeviceCapabilities
An object holding the capabilities of the payment terminal.
Property | Description |
---|---|
printer Boolean |
True if the terminal has printer, false otherwise |
cloudApi Boolean |
True if the terminal is cloud-enabled, false otherwise |
DeviceStatus
A class which holds the status of the payment terminal.
Property | Description |
---|---|
SerialNumber String |
Gets the serial number of the payment terminal |
BatteryStatus String |
Gets the battery status of the payment terminal (in percentages) |
BatterymV String |
Gets the battery voltage of the payment terminal |
BatteryCharging String |
Gets the battery charging status of the payment terminal |
ExternalPower String |
Gets the status of the payment terminal external power |
ApplicationName String |
Gets the application name of the payment terminal |
ApplicationVersion String |
Gets the application version of the payment terminal |
DeviceParameter
An enum describing all the admin commands to send to a payment terminal.
BluetoothName
BluetoothPass
SystemTimeout
ScreenTimeout
SignatureTimeout
Balance
Balance available on the card
Property | Description |
---|---|
amount Integer |
The amount balance |
currency Curreny |
The balance currency |
sign BalanceSign |
Positive (C) or negative (D) balance. You can retrieve the balance sign using the methods isPositive() or isNegative() |
Balance balance = Balance.Companion.factory(
"1000",
Currency.EUR.getAlpha(),
BalanceSign.POSITIVE_SIGN.name()
)
FinancialStatus
An enum representing different statuses of a finalized transaction
UNDEFINED
AUTHORISED
DECLINED
PROCESSED
FAILED
CANCELLED
PARTIAL_APPROVAL
Manufacturer
A string representing different payment terminal supported manufacturers.
INVALID
DATECS
PAX
TELPO
MoToChannel
A enum representing the channel used for the card not present transaction (MO = Mail Order / TO = Telephone Order) .
MO
TO
CardSchemeName
A string representing different card brands.
MasterCard
Visa
Maestro
American Express
Discover
JCB
Diners
UnionPay
HapiFactory
A factory to provide a unified entrypoint and simplify the instantiation of the Hapi object.
getAsyncInterface( Events.Required requiredListener , Context context , HandpointCredentials handpointCredentials );
Parameter | Notes |
---|---|
requiredListener *
Events.Required |
A listener object to report the required events. |
context *
Context |
The Android context. |
handpointCredentials *
HandpointCredentials |
An object containing the actor's shared secret key or shared secret key AND Api Key for CLOUD connections. |
//InitApi for Datecs devices or PAX/Telpo ConnectionMethod.ANDROID_PAYMENT
public void InitApi()
{
String sharedSecret = "0102030405060708091011121314151617181920212223242526272829303132";
api = HapiFactory.getAsyncInterface(this, new HandpointCredentials(sharedSecret));
//The api is now initialized. Yay! we've even set a default shared secret
}
//InitApi for Cloud devices
public void InitApi()
{
String sharedSecret = "0102030405060708091011121314151617181920212223242526272829303132";
String apikey = "This-Is-The-Merchant-Api-Key";
api = HapiFactory.getAsyncInterface(this, new HandpointCredentials(sharedSecret, apikey));
//The api is now initialized. Yay! we've even set a default shared secret and the merchant Api Key!
}
HapiManager
A static class containing information about the current status of the SDK
Property | Description |
---|---|
DefaultSharedSecret String |
Gets the default shared secret in use. |
LogLevel LogLevel |
Gets the current log level of the SDK and payment terminal. |
inTransaction boolean |
Checks whether the SDK is in the middle of a transaction. True if the SDK is in a transaction, false otherwise. |
SdkVersion String |
Gets the current SDK version. |
isTransactionResultPending boolean |
In the case of a communication failure between the payment terminal and the SDK a TransactionResult might have not been delivered. This function checks if there is a pending TransactionResult. This field is only updated when connecting to a payment terminal. If this function returns true the TransactionResult (which includes the receipt) can be fetched.getPendingTransactionResult();. This function serves the same functionality as the event pendingTransactionResult(Device device), so every time this event is invoked, HapiManager.IsTransactionResultPending() is true until the result is fetched. |
Settings.AutomaticReconnection boolean |
When this property is set to true, the SDK will automatically try to reconnect to the payment terminal after a disconnection. The SDK internally maintains a reconnection thread which keeps on trying to connect until it succeeds. The delay between reconnections is exponentially increased on every new attempt. The default value for this property is true |
//Check if the SDK is in transaction
boolean inTransaction = HapiManager.inTransaction(someConnectedDevice);
//Check the current logLevel
LogLevel level = HapiManager.getLogLevel();
//Disable automatic reconnection feature
HapiManager.Settings.AutomaticReconnection = false;
HandpointCredentials
A class containing the credentials used to communicate with the payment terminal, the shared secret (always required) and Cloud API Key (ony required when using CLOUD connection method).
Property | Description |
---|---|
SharedSecret String |
String the value of the Shared secret. |
CloudApiKey String |
String the value of the merchant Cloud API Key, only required when using CLOUD connection method |
{
String sharedSecret = "0102030405060708091011121314151617181920212223242526272829303132";
HandpointCredentials handpointCredentials = new HandpointCredentials(sharedSecret);
//We've even set a default shared secret!
}
{
String sharedSecret = "0102030405060708091011121314151617181920212223242526272829303132";
string apikey = "This-Is-The-Merchant-Api-Key";
HandpointCredentials handpointCredentials = new HandpointCredentials(sharedSecret, apikey);
//We've even set a default shared secret and the merchant Api Key!
}
LogLevel
An enum describing the different levels of logging available.
None
Info
Full
Debug
OptionalParameters
A class containing optional transaction parameters supported by the payment terminal.
Property | Description |
---|---|
Budget String |
Budget is only available for sale transactions. A String representing the key for a budget number.A budget number can be used to split up an amout over a period of months. The value has to be a |
CustomerReference String |
CustomerReference is available for all transactions. A String representing the key for a customer reference. A customer reference can be used for an internal marking system. The value is sent as a |
PrintError
An enum representing different errors that can come from print action.
Unexpected
InvalidArgument
CantConnectToPrinter
NotSupported
NoPermission
PrinterDisabled
NotWhitelisted
Busy
OutOfPaper
DataPacketInvalid
PrinterHasProblems
PrinterOverheating
PrintingUnfinished
FontNotPresent
FontFormatError
TooLong
BatteryTooLow
PaperCutterError
PaperCutterJam
CoverOpen
UnsupportedEncoding
PaymentScenario
An enum representing different types of scenario.
UNKNOWN
MAGSTRIPE
MAGSTRIPECONTACTLESS
CHIP
CHIPCONTACTLESS
CHIPFAILMAGSTRIPE
CardBrands
A string representing the supported card brands.
VISA
MASTERCARD
MAESTRO
AMEX
DISCOVER
DINERS
JCB
INTERAC
OTHER
Settings
An Object holding the SDK initialization settings
Property | Description |
---|---|
automaticReconnection Boolean |
When this property is set to true, the SDK will automatically try to reconnect to the terminal after disconnection. The SDK maintains internally a reconnection thread which keeps on trying to connect until it succeeds. The delay between reconnections is exponentially increased on every new attempt. The default value for this property is false |
autoRecoverTransactionResult Boolean |
. The default value for this property is false |
sendToDeviceMaxAttempts Integer |
Number of retry attemps when there is an error communicating with the card reader. The default value for this property is 3 |
timeBetweenAttempts Integer |
Time in milliseconds between attempts. The default value for this property is 5000 |
showSDKUIComponents Boolean |
. The default value for this property is false |
getReceiptsAsURLs Boolean |
. The default value for this property is false |
SignatureRequest
A class containing information about a signature verification.
Property | Description |
---|---|
Timeout int |
int the value of the timeout in seconds. |
MerchantReceipt String |
String the merchant receipt as html. |
statusInfo
A class containing information about the status of the transaction.
Property | Description |
---|---|
isCancelAllowed bool |
A boolean letting the integrator know if the terminal will accept a stop transaction request. |
status Status |
A Status enum representing the status of the transaction. |
cardLanguage SupportedLocales |
The card language preference in all supported locales. |
multiLanguageMessages Map |
map containing the status message in a human readable format in all the supported locales. |
message String |
A String containing the status message of the transaction. |
deviceStatus DeviceStatus |
A DeviceStatus object containing information about the payment terminal. |
status
An enum containing information about the status of a transaction.
Undefined
Success
InvalidData
ProcessingError
CommandNotAllowed
NotInitialised
ConnectTimeout
ConnectError
SendingError
ReceivingError
NoDataAvailable
TransactionNotAllowed
UnsupportedCurrency
NoHostAvailable
CardReaderError
CardReadingFailed
InvalidCard
InputTimeout
UserCancelled
InvalidSignature
WaitingForCard
CardInserted
ApplicationSelection
ApplicationConfirmation
AmountValidation
PinInput
ManualCardInput
WaitingForCardRemoval
TipInput
SharedSecretInvalid
SharedSecretAuth
WaitingSignature
WaitingHostConnect
WaitingHostSend
WaitingHostReceive
WaitingHostDisconnect
PinInputCompleted
PosCancelled
RequestInvalid
CardCancelled
CardBlocked
RequestAuthTimeout
RequestPaymentTimeout
ResponseAuthTimeout
ResponsePaymentTimeout
IccCardSwiped
RemoveCard
ScannerIsNotSupported
ScannerEvent
BatteryTooLow
AccountTypeSelection
BtIsNotSupported
PaymentCodeSelection
PartialApproval
AmountDueValidation
InvalidUrl
WaitingCustomerReceipt
PrintingMerchantReceipt
PrintingCustomerReceipt
UpdateStarted
UpdateFinished
UpdateFailed
UpdateProgress
WaitingHostPostSend
WaitingHostPostReceive
Rebooting
PrinterOutOfPaper
ErrorConnectingToPrinter
CardTapped
ReceiptPrintSuccess
InvalidPinLength
OfflinePinAttempt
OfflinePinLastAttempt
ProcessingSignature
CardRemoved
TipEntered
CardLanguagePreference
AutomaticPrintingStarted
CancelOperationNotAllowed
UpdateSoftwareStarted
UpdateSoftwareFinished
UpdateSoftwareFailed
UpdateSoftwareProgress
InstallSoftwareStarted
InstallSoftwareFinished
InstallSoftwareFailed
InstallSoftwareProgress
UpdateConfigStarted
UpdateConfigFinished
UpdateConfigFailed
UpdateConfigProgress
InitialisationComplete
SupportedLocales
An enum of the SDK supported languages.
en_CA
en_UK
en_US
es_ES
hr_HR
is_IS
fr_FR
pt_PT
PaxA80Keys
A string representing the PAX A80 physical keyboard keys.
0
1
2
3
4
5
6
7
8
9
GREEN
ORANGE
RED
FUNC
OPTIONS
TenderType
An enum representing different tender types.
NOT_SET
CREDIT
DEBIT
TipConfiguration
TipConfiguration( String tipAmount );
Parameter | Notes |
---|---|
tipAmount
String |
If present, the amount of the tip to be used for the transaction. |
Property | Description |
---|---|
amount BigInteger |
Transaction amount in the minor unit of currency (f.ex. 1000 is 10.00 GBP). |
baseAmount BigInteger |
Base amount used to calculate the tip - in the minor unit of currency (f.ex. 1000 is 10.00 GBP). If no base amount is defined, the transaction amount is used as base amount. |
headerName String |
Name of the tipping menu appearing on the terminal. Default: Tip |
tipPercentages List<Integer> |
List of percentages used to calculate the tip amount. REQUIRED |
enterAmountEnabled Boolean |
Flag used to enable the cardholder to manually enter the tip amount. Default: true |
skipEnabled Boolean |
Flag used to enable the cardholder to skip the tipping step. Default: true |
footer String |
Footer note which will appear on the tipping menu. Default: Empty string |
{
"amount": "2000",
"baseAmount": "2000",
"headerName": "",
"tipPercentages": [5,10,15,20,25],
"enterAmountEnabled": true,
"skipEnabled": false,
"footer": "Thank you!!! ;)"
}
TransactionType
An enum representing different types of transactions.
UNDEFINED
SALE
VOID_SALE
REFUND
VOID_REFUND
REVERSAL
CANCEL_SALE
CANCEL_REFUND
TOKENIZE_CARD
SALE_AND_TOKENIZE_CARD
CARD_PAN
TypeOfResult
An enum representing different types of device reports.
STATUS
REPORT
BLUETOOTHNAME
EMVCONFIGURATION
VerificationMethod
An enum representing different verification methods used in the transaction.
UNDEFINED
SIGNATURE
PIN
PIN_SIGNATURE
FAILED
NOT_REQUIRED
MOBILE_PASS_CODE