Introduction

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.

Awesomely simple
Created for humans, coders, geeks, no need of a dark and complex knowledge of the payment industry.
Super secure
We take care of PCI compliance so you can be kept out of scope
The Handpoint terminals encrypt all sensitive cardholder data so your app does not have to deal with it.
Available through Maven Central
The Handpoint Android SDK is compatible with Android version 5.1.1 (API level 22) and up.
The latest version is compiled with java 1.8

Maven:
                    	
    <dependency>
      <groupId>com.handpoint.api</groupId>
      <artifactId>sdk</artifactId>
      <version>[6.0.0,7.0.0)</version>
      <type>aar</type>
    </dependency>
                    	
                
Gradle:
                    	
    implementation 'com.handpoint.api:sdk:6.+'





                    	
                

If you have any questions, do not hesitate to contact us.

version

Get the SDK

Migration from 5.X

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.

  1. For a Sale or Sale and Tokenize operation, please see SaleOptions
  2. 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);
                        
                    
  3. Similar to SaleOptions, but with less possible parameters, for a Refund operation, please see RefundOptions
  4. 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);
                        
                    
  5. For the rest of operations, please see Options
  6. If you use a customer reference:

                        
    	options.setCustomerReference("Your customer reference");
                        
                    

API overview

Supported functionality

  • List the available payment terminals
  • Connect/disconnect to and from a payment terminal.
  • Automatically or manually reconnect to a payment terminal.
  • Execute financial transactions.
  • Get the status of transactions.
  • Control and access the device logs.

Processing Payments Simulation

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


Integration Guide

We support the following connection methods

  1. Android Payment Terminal
  2. Bluetooth
  3. Cloud

Android Terminal Native Integration

Introduction

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

Let's start programming!

  1. Modify the AndroidManifest.xml
  2. We strongly recommend you add the following to your main <activity>:

    android:launchMode="singleTask"
  3. In the gradle.build
  4. 
    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'
        }
    }
    
  5. Create a Java class
  6. 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
        }
    }
                    

We're done!

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.

Bluetooth Integration

Introduction

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

Let's start programming!

  1. Modify the AndroidManifest.xml
  2. We strongly recommend you add the following to your main <activity>:

    android:launchMode="singleTask"
  3. In the gradle.build
  4. 
    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'
        }
    }
    
  5. Create a Java class
  6. 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.

We're done!

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.

Cloud Integration

Introduction

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

Let's start programming!

  1. In the gradle.build
  2. 
    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'
      }
    }
    
  3. Create a Java class
  4. 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
        }
    
    }
                    

We're done!

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.

Transactions

Sale

method Available since 6.0.0

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.

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.


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry').
signatureRequired
Invoked if card verification requires signature.
endOfTransaction
Invoked when the terminal finishes processing the transaction.

Returns

Boolean
true if the operation was successfully sent to the terminal

Code example

//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);

Sale And Tokenize Card

method Available since 6.0.0

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)

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.


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry').
signatureRequired
Invoked if card verification requires signature.
endOfTransaction
Invoked when the terminal finishes processing the transaction.

Returns

Boolean
true if the operation was successfully sent to the terminal

Code example

//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 Reversal

method Available since 6.0.0

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.

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
originalTransactionID *
String
Id of the original sale transaction
options
MerchantAuthOptions
An object to store all the customization options for the transaction.


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry').
signatureRequired
Invoked if card verification requires signature.
endOfTransaction
Invoked when the terminal finishes processing the transaction.

Returns

Boolean
true if the operation was successfully sent to the terminal

Code example

//Initiate a reversal for 10.00 in Great British Pounds
api.saleReversal(new BigInteger("1000"),Currency.GBP,"00000000-0000-0000-0000-000000000000");

Refund

method Available since 6.0.0

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.

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
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.


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry')
signatureRequired
Invoked if card verification requires signature.
endOfTransaction
Invoked when the terminal finishes processing the transaction

Returns

Boolean
true if the operation was successfully sent to terminal

Code example

//Initiate a refund for 10.00 in Great British Pounds
api.refund(new BigInteger("1000"),Currency.GBP,"00000000-0000-0000-0000-000000000000");

Refund reversal

method Available since 6.0.0

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.

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
originalTransactionID *
String
transaction id of the original refund
options
MerchantAuthOptions
An object to store all the customization options for the transaction.


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry')
signatureRequired
Invoked if card verification requires signature.
endOfTransaction
Invoked when the terminal finishes processing the transaction

Returns

Boolean
true if the operation was successfully sent to the terminal

Code example

//Initiate a refund reversal for 10.00 in Great British Pounds
api.refundReversal(new BigInteger("1000"),Currency.GBP,"00000000-0000-0000-0000-000000000000");

Signature result

method Available since 6.0.0

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.

Parameters

Parameter Notes
accepted *
Boolean
pass true if merchant accepts cardholder signature


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry').
endOfTransaction
Invoked when the terminal finishes processing the transaction.

Returns

Boolean
true if the operation was successfully sent to the terminal.

Code example

//Approves signature automatically in signatureRequired event
@Override
public void signatureRequired(SignatureRequest signatureRequest, Device device){
	api.signatureResult(true);
}

Tip Adjustment

method Available since 3.3.0

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.

Parameters

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)


Returns

FinancialStatus

Result of the tip adjustment transaction, it returns a FinancialStatus, the possible values are :

- FinancialStatus.AUTHORISED (tip adjustment approved by the processor)
- FinancialStatus.FAILED (system error or timeout)
- FinancialStatus.DECLINED (tip adjustment declined by the processor)

If two tip adjustments are sent for the same sale transaction, the second tip adjustment will override the first one. In case the transaction fails (not declined) we recommend that you prompt the user of the POS to retry the adjustment.

Code example

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
	}
});

Tokenize Card

method Available since 6.0.0

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)

Parameters

Parameter Notes
options
Options
An object to store all the customization options for the transaction.


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry').
endOfTransaction
Invoked when the terminal finishes processing the transaction.

Returns

Boolean
true if the operation was successfully sent to the terminal

Code example

//Tokenize a card
api.tokenizeCard();

Card PAN

method Available since 6.0.0

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.

Parameters

Parameter Notes
options
Options
An object to store all the customization options for the transaction.


Events invoked

currentTransactionStatus
Invoked during a transaction, it fetches statuses coming from the terminal (ex : 'waiting for card' or 'waiting for PIN entry').
endOfTransaction
Invoked when the terminal finishes processing the transaction.

Returns

Boolean
true if the operation was successfully sent to the terminal

Code example

//Gets the PAN of a card
api.cardPan();

Device management

Connect

method Available since 5.0.0

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.

Parameters

Parameter Notes
device *
Device
This parameter specifies which device type you want to connect to.


Events invoked

connectionStatusChanged
Each time the card reader state changes (ex : going from Connected to Disconnected) the ConnectionStatusChanged event is called. It causes the connection manager to invoke this event with the appropriate information.

Returns

Boolean
true if the operation was successful.

Code example

//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);

Disconnect

method Available since 5.0.0

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.

Events invoked

connectionStatusChanged
Causes the connection manager to invoke this event with the appropriate information.

Returns

Boolean
true if the operation was successful.

Code example

//Disconnect from current device
api.Disconnect();

Get EMV Report

method Available since 6.0.0

getEMVConfiguration

Fetches the logs from the device and reports them to the deviceLogsReady event.

Events invoked

reportResult
Invoked when hapi has finished downloading the EMV report from the card reader.

Returns

Boolean
true if the operation was successfully sent to device

Code example

//Downloads logs from device
api.getDeviceLogs();

Get Paired Devices

method Available since 5.0.0

getPairedDevices

Returns the payment terminals associated with the specified ConnectionMethod

Parameters

Parameter Notes
method *
ConnectionMethod
The type of connection with the payment terminal (Bluetooth, Cloud, etc.).


Returns

List<Device>
The list of payment terminals.

Code example

// Get paired terminals
List<Device> devices = api.getPairedDevices(ConnectionMethod.XXX);

Request device logs

method Available since 6.0.0

getDeviceLogs

Fetches the logs from the device and reports them to the deviceLogsReady event.

Events invoked

deviceLogsReady
Invoked when hapi has finished downloading logs from the card reader.

Returns

Boolean
true if the operation was successfully sent to device

Code example

//Downloads logs from device
api.getDeviceLogs();

Get Device Manufacturer

method Available since 6.0.0

getDeviceManufacturer

Returns the manufacturer of the payment terminal

Returns

Manufacturer
The payment terminal manufacturer

Code example

Manufacturer manufacturer = api.getDeviceManufacturer();

Flash Reset

method Available since 6.0.0

deleteDeviceConfig

Sends a command to the terminal to delete its configuration

Code example

api.deleteDeviceConfig();

Print Receipt

method Available since 5.0.0

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.

Parameters

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.


Returns

Boolean
true if the receipt was sent to the printer, false otherwise

Code example

//Print a receipt with Handpoint logo (bitmap format)
String validReceipt = "<html><body><img src=''></body></html>";
boolean success = api.printReceipt(validReceipt);

Search Devices

method Available since 5.0.0

searchDevices

Starts the search of payment terminals associated with the specified ConnectionMethod

Parameters

Parameter Notes
method *
ConnectionMethod
The type of connection with the payment terminal (Bluetooth, Cloud, etc.).


Events invoked

deviceDiscoveryFinished
Returns a list of payment terminals.

Code example

// 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);

Set Locale

method Available since 5.14.0

setLocale

Sets the SDK Locale (language). It is used to set the SDK language as well as the associated date and number formatting.

Parameters

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.


Code example

// Set canadian english
api.setLocale(SupportedLocales.en_CA);

Set logging level

method Available since 3.2.4

setLogLevel

Sets the log level (info, debug...) for both the payment terminal and the SDK.

Parameters

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.


Events invoked

None
No events are invoked.

Returns

Boolean
true if the operation was successfully sent to device

Code example

//Sets the log level to info
api.setLogLevel(LogLevel.info);

Stop current transaction

method Available since 5.0.0

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.

Events invoked

currentTransactionStatus
Invoked after stop transaction. Status UserCancelled will be reported
endOfTransaction
Transaction will fail with status CANCELLED

Returns

Boolean
true if the transaction was successfully stopped, false otherwise

Code example

// Stops current transaction 
if (api.stopCurrentTransaction()) { 
	...
} else { 
	...
}

Update device

method Available since 3.2.4

update

The update operation checks for new software or configuration updates and initiates a download if required.

Parameters

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.


Events invoked

None
The merchant should be notified about the update process.

Returns

Boolean
true if the operation was successfully sent to device

Code example

//Check for card reader update
api.update();

Events subscribers

Register events delegate

method Available since 5.0.0

registerEventsDelegate

Registers a delegate for the SDK events.

Parameters

Parameter Notes
listener *
Object
Any Object implementing one or more of the available delegate interfaces.


Returns

Boolean
True if the new delegate was added successfully

Code example

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);
		...
	}

}

Unregister events delegate

method Available since 5.0.0

unregisterEventsDelegate

Unregisters an object from SDK events.

Parameters

Parameter Notes
listener *
Object
Any Object implementing one or more of the available delegate interfaces.


Returns

Boolean
True if the new delegate was removed successfully

Code example

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 listeners

All

interface Available since 6.0.0

Events.All

An interface which needs to be implemented and added as a listener to receive all available events.

Extends

Required Log Status PendingResults ReportResult PrinterEvents TransactionStarted MessageHandling CardLanguage

Basic

interface Available since 5.0.0

Events.Basic

An interface which needs to be implemented and added as a listener to receive basic events.

Extends

Required Log Status PendingResults ReportResult

Connection status changed

interface Available since 5.10.0

Events.ConnectionStatusChanged

Implement this interface in order to receive connection status changes.

Methods

connectionStatusChanged( ConnectionStatus status , Device device );

Parameter Notes
status *
ConnectionStatus
New status of the connection
device *
Device
The terminal which sent this information.

Code example

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);

Current transaction status

interface Available since 5.0.0

Events.CurrentTransactionStatus

Implement this interface in order to receive events about the current transaction.

Methods

currentTransactionStatus( StatusInfo status , Device device );

Parameter Notes
status *
StatusInfo
The StatusInfo of the current transaction
device *
Device
The terminal the request is sent from.

Code example

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);

Device capabilities ready

interface Available since 5.0.0

Events.DeviceCapabilitiesReady

Implement this interface in case the terminal needs to notify the SDK of its capabilities

Methods

deviceCapabilities( DeviceCapabilities capabilities , Device device );

Parameter Notes
capabilities *
DeviceCapabilities
The capabilities of the terminal
device *
Device
The terminal sending its capabilities

Code example

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);

Device discovery finished

interface Available since 5.0.0

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

Methods

deviceDiscoveryFinished( List<Device> devices );

Parameter Notes
devices *
List<Device>
A list of available devices.

Code example

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);

End of transaction

interface Available since 5.0.0

Events.EndOfTransaction

Implement this interface to receive an event when a transaction is complete.

Methods

endOfTransaction( TransactionResult result , Device device );

Parameter Notes
result *
TransactionResult
Holds all the information about the transaction.
device *
Device
The payment terminal.

Code example

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);

Hardware status changed

interface Available since 5.0.0

Events.HardwareStatusChanged

Implement this interface in order to receive events when the hardware status changes.

Methods

hardwareStatusChanged( HardwareStatus status , Device device );

Parameter Notes
status *
HardwareStatus
New status of the hardware.
device *
Device
The payment terminal.

Code example

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);

Log

interface Available since 5.3.1

Events.Log

An interface which needs to be implemented and added as a listener to receive logging information.

Extends

OnMessageLogged

Code example

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);

MessageHandling

interface Available since 5.8.0

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.

Methods

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

Code example

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);

On message logged

interface Available since 5.0.0

Events.OnMessageLogged

Implement this interface to receive logs from the payment terminal. You must call getDeviceLogs to request the logs.

Methods

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.

Code example

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);

PaymentProvider

interface Available since 5.0.0

Events.PaymentProvider

An interface which needs to be implemented and added as a listener to receive all available events related to financial operations.

Extends

SignatureRequired EndOfTransaction OnMessageLogged CurrentTransactionStatus

PendingResults

interface Available since 5.0.0

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.

Extends

TransactionResultReady

Code example

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);

PrinterEvents

interface Available since 5.8.0

Events.PrinterEvents

An interface which needs to be implemented and added as a listener to get events coming from the printer.

Methods

printSuccess( );

Parameter Notes

printError( PrintError error );

Parameter Notes
error *
PrintError
Enum detailing the reason of the error

Code example

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);

Report result

interface Available since 5.0.0

Events.ReportResult

Implement this interface to receive an event when a report result from a getReport is returned

Methods

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

Code example

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);

Required

interface Available since 5.0.0

Events.Required

You must provide a class implementing this interface when initializing the SDK.

Extends

SignatureRequired EndOfTransaction DeviceDiscoveryFinished PendingResults

Code example

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);

Signature required

interface Available since 5.0.0

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.

Methods

signatureRequired( SignatureRequest request , Device device );

Parameter Notes
request *
SignatureRequest
Holds the signature request.
device *
Device
The payment terminal.

Code example

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);

Status

interface Available since 5.0.0

Events.Status

An interface which needs to be implemented and added as a listener to receive connection and transaction statuses.

Extends

ConnectionStatusChanged HardwareStatusChanged CurrentTransactionStatus

Code example

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);

Transaction result ready

interface Available since 5.0.0

Events.TransactionResultReady

Implement this interface in order to receive an event after a pending TransactionResult has been recovered from the payment terminal.

Methods

transactionResultReady( TransactionResult transactionResult , Device device );

Parameter Notes
transactionResult *
TransactionResult
A TransactionResult is containing all information about the recovered transaction.
device *
Device
The payment terminal.

Code example

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);

Transaction started

interface Available since 5.0.0

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.

Methods

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

Code example

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);

Objects

Transaction Result

object Available since 6.0.0

TransactionResult

An object holding information about the result of a transaction.

Properties

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"

Code example

{
  "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
}

Acquirer

enum Available since 6.0.0

Acquirer

An enum representing all the supported acquirers for merchant authentication

Possible values

AMEX BORGUN EVO OMNIPAY POSTBRIDGE INTERAC TSYS VANTIV SANDBOX

Code example

public enum Acquirer {	AMEX,
	BORGUN,
	EVO,
	OMNIPAY,
	POSTBRIDGE,
	INTERAC,
	TSYS,
	VANTIV,
	SANDBOX
}

Card Entry Type

enum Available since 3.0.0

CardEntryType

An enum representing different card entry types.

Possible values

UNDEFINED MSR ICC CNP

Connection Method

enum Available since 5.3.1

ConnectionMethod

An enum representing different connection methods with the payment terminal.

Currently BLUETOOTH, SIMULATOR, CLOUD and ANDROID_PAYMENT are supported types.

Possible values

USB SERIAL BLUETOOTH CLOUD ANDROID_PAYMENT HTTPS WIFI ETHERNET SIMULATOR

Code example

//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
}

Connection Status

enum Available since 5.3.1

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).

Possible values

Connected Connecting Disconnected Disconnecting NotConfigured Initializing CloudConnected CloudInitialized CloudAvailable CloudDisconnected CloudUnavailable

Currency

enum Available since 3.0.0

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.

Possible values

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

Balance Sign

String Available since 1.0.0

BalanceSign

An enum representing the balance sign

Possible values

POSITIVE_SIGN('C') NEGATIVE_SIGN('D')

Sale Options

object Available since 6.0.0

SaleOptions

An object to store all the customization options for a sale.

Properties

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

Code example

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));

Refund Options

object Available since 6.0.0

RefundOptions

An object to store all the customization options for a refund.

Properties

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

Code example

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

object Available since 6.0.0

Options

An object to store customer reference options for regular operations.

Properties

Property Description
CustomerReference
String
An arbitrary string to use as your own identifier for a transaction

Code example

Options options = new Options();

//If you use a customer reference
options.setCustomerReference("Your customer reference");

Merchant Auth Options

object Available since 6.0.0

MerchantAuthOptions

An object to store merchant authentication options for regular operations.

Properties

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

Code example

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);

Merchant Auth

object Available since 6.0.0

MerchantAuth

An object to store merchant authentication.

Methods

Constructor

MerchantAuth( );

Constructor

MerchantAuth( Credential credential );

Parameter Notes
credential
Credential
If present, adds the given credential to the list.

Constructor

MerchantAuth( List<Credential> credentials );

Parameter Notes
credentials
List<Credential>
If present, the list of credentials.

Add Credential

add( Credential credential );

Parameter Notes
credential *
Credential
The credential to be added.

Code example

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);

Device

object Available since 5.3.1

Device

An object to store the information about the payment terminal in use.

Methods

Constructor

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.

Properties

Property Description
Id
String
A unique identifier for the payment terminal.

Code example

//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);

Device capabilities

object Available since 5.0.0

DeviceCapabilities

An object holding the capabilities of the payment terminal.

Properties

Property Description
printer
Boolean
True if the terminal has printer, false otherwise
cloudApi
Boolean
True if the terminal is cloud-enabled, false otherwise

Balance

object Available since 1.0.0

Balance

Balance available on the card

Properties

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()

Code example

Balance balance = Balance.Companion.factory(
    "1000", 
    Currency.EUR.getAlpha(), 
    BalanceSign.POSITIVE_SIGN.name()
  )

Device Parameter

enum Available since 3.0.0

DeviceParameter

An enum describing all the admin commands to send to a payment terminal.

Possible values

BluetoothName BluetoothPass SystemTimeout ScreenTimeout SignatureTimeout

Device Status

object Available since 3.2.1

DeviceStatus

A class which holds the status of the payment terminal.

Properties

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

Merchant Auth Credential

object Available since 6.0.0

Credential

An object to store credentials (Mid, Tid, Acquirer) for merchant authentication.

Methods

Constructor

Credential( Acquirer Acquirer , String Mid , String Tid );

Parameter Notes
Acquirer
Acquirer
If present, it links this credential to the specified acquirer. It's required if more than one credential is provided.
Mid
String
For this transaction, replaces the default MID (merchant ID) that the terminal has in its configuration.
Tid
String
For this transaction, replaces the default TID (terminal ID) that the terminal has in its configuration.

Properties

Property Description
Acquirer
Acquirer
If present, it links this credential to the specified acquirer. It's required if more than one credential is provided.
Mid
String
For this transaction, replaces the default MID (merchant ID) that the terminal has in its configuration.
Tid
String
For this transaction, replaces the default TID (terminal ID) that the terminal has in its configuration.

Code example

Credential credential = new Credential();
//Optionally
credential.setAcquirer(YOUR_ACQUIRER);
//Optionally
credential.setMerchantId(mid);
//Optionally
credential.setTerminalId(tid);

Financial Status

enum Available since 4.0.1

FinancialStatus

An enum representing different statuses of a finalized transaction

Possible values

UNDEFINED AUTHORISED DECLINED PROCESSED FAILED CANCELLED PARTIAL_APPROVAL

Manufacturer

enum Available since 6.0.0

Manufacturer

A string representing different payment terminal supported manufacturers.

Possible values

INVALID DATECS PAX TELPO

Card Scheme Name

String Available since 5.17.3

CardSchemeName

A string representing different card brands.

Possible values

MasterCard Visa Maestro American Express Discover JCB Diners UnionPay

Hapi Manager

object Available since 3.2.5

HapiManager

A static class containing information about the current status of the SDK

Properties

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

Code example

//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;

Handpoint API (Hapi) factory

object Available since 5.3.1

HapiFactory

A factory to provide a unified entrypoint and simplify the instantiation of the Hapi object.

Methods

Static factory

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.

Code example

//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!
}

Handpoint Credentials

object Available since 5.3.1

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).

Properties

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

Code example

{
	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!
}

Log Level

enum Available since 3.0.0

LogLevel

An enum describing the different levels of logging available.

Possible values

None Info Full Debug

Optional Transaction Parameters

object Available since 3.0.0

OptionalParameters

A class containing optional transaction parameters supported by the payment terminal.

Properties

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 String of 2 digits representing the number of months to split the transaction to.

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 String of a maximum 25 characters and received back when the transaction has been processed.

Payment Scenario

enum Available since 6.0.0

PaymentScenario

An enum representing different types of scenario.

Possible values

UNKNOWN MAGSTRIPE MAGSTRIPECONTACTLESS CHIP CHIPCONTACTLESS CHIPFAILMAGSTRIPE

Print Error

enum Available since 5.8.0

PrintError

An enum representing different errors that can come from print action.

Possible values

Unexpected InvalidArgument CantConnectToPrinter NotSupported NoPermission PrinterDisabled NotWhitelisted Busy OutOfPaper DataPacketInvalid PrinterHasProblems PrinterOverheating PrintingUnfinished FontNotPresent FontFormatError TooLong BatteryTooLow PaperCutterError PaperCutterJam CoverOpen UnsupportedEncoding

Status

enum Available since 6.0.0

status

An enum containing information about the status of a transaction.

Possible values

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

Supported Locales

enum Available since 5.14.0

SupportedLocales

An enum of the SDK supported languages.

Possible values

en_CA en_UK en_US es_ES hr_HR is_IS fr_FR pt_PT

Settings

object Available since 5.0.0

Settings

An Object holding the SDK initialization settings

Properties

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

Status Info

object Available since 3.5.5

statusInfo

A class containing information about the status of the transaction.

Properties

Property Description
cancelAllowed
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.
message
String
A String containing the status message of the transaction.
deviceStatus
DeviceStatus
A DeviceStatus object containing information about the payment terminal.

Signature Request

object Available since 3.2.1

SignatureRequest

A class containing information about a signature verification.

Properties

Property Description
Timeout
int
int the value of the timeout in seconds.
MerchantReceipt
String
String the merchant receipt as html.

Tender Type

enum Available since 5.11.0

TenderType

An enum representing different tender types.

Possible values

NOT_SET CREDIT DEBIT

Tip Configuration

object Available since 6.0.0

TipConfiguration

Methods

Constructor

TipConfiguration( String tipAmount );

Parameter Notes
tipAmount
String
If present, the amount of the tip to be used for the transaction.

Properties

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

Code example

{
    "amount": "2000",
    "baseAmount": "2000",
    "headerName": "",
    "tipPercentages": [5,10,15,20,25],
    "enterAmountEnabled": true,
    "skipEnabled": false,
    "footer": "Thank you!!! ;)"
}

Transaction Type

enum Available since 5.9.0

TransactionType

An enum representing different types of transactions.

Possible values

UNDEFINED SALE VOID_SALE REFUND VOID_REFUND REVERSAL CANCEL_SALE CANCEL_REFUND TOKENIZE_CARD SALE_AND_TOKENIZE_CARD CARD_PAN

Type of result

enum Available since 5.0.0

TypeOfResult

An enum representing different types of device reports.

Possible values

STATUS REPORT BLUETOOTHNAME EMVCONFIGURATION

Verification Method

enum Available since 5.17.0

VerificationMethod

An enum representing different verification methods used in the transaction.

Possible values

UNDEFINED SIGNATURE PIN PIN_SIGNATURE FAILED NOT_REQUIRED MOBILE_PASS_CODE