Integrating a smartcard reader solution

Properties of a smartcard reader solution through the Reader API

In order to operate smartcard reader solutions, a ticketing application on a Keyple-based terminal uses the « generic » terminal reader API. The use of this interface is independent of the Keyple solution. The Reader API categorizes the smartcard readers into 2 types:

  • “simple” card readers, which only manage “synchronously” the card application selection,
  • “observable” card readers, which also support “asynchronous” card application selection.

In general, all “contactless” reader solutions are observable, because for these readers the smartcard is always removable: it is necessarily necessary to notify applications of card insertion or removal events from the reader’s RF field. -On the other hand, for some “contact” reader solutions, card presence is statically defined: these readers don’t need to be observed.

Properties of a smartcard reader solution through the Keyple Service API

For a Keyple-based terminal, smartcard reader solutions are interfaced using reader plug-ins. Keyple’s Service API enables ticketing terminal applications to access “locally” 3 categories of reader solutions:

  • a “simple” plugin enables only static configuration of smartcard readers → the most common case in embedded systems.
  • an “observable” plugin enables the management of reader solutions that can be hot-plugged or hot-disconnected. → mainly 2 uses: readers connected over serial links (e.g. USB), or mobile solutions with an energy-saving mode (reader power supply cut off at standby).
  • a “pool” plugin for interfacing with solutions offering dynamic allocation of reader resources according to the need. → this is how an HSM-type solution works.

Integrating a smartcard reader solution into Keyple through the Plugin API

For a Keyple-based terminal, a dedicated plug-in for any smart card reader solution must implement Keyple’s Plugin API:

  • SPIs are differentiated in particular for the 2 reader types and the 3 plug-in categories.
  • other features are linked to the native API capabilities of reader solutions:
    • autonomy to manage the Select Application command
    • autonomous synchronous, autonomous asynchronous or non-autonomous card insertion detection,
    • detection of card withdrawal at the end of a transaction, managed autonomously (synchronous or asynchronous) or non-autonomous,
    • ability to detect card removal during a card transaction

The Keyple project offers a guide for developing plugins to integrate smartcard reader solutions.

Additional ‘Reader Plugins’ provided by CNA

The Keyple project already hosts several plugins for interfacing with “standard” smartcard reader solutions (PC/SC, Android NFC / OMAPI), or for emulating readers.

To illustrate some other ways of designing plugins, CNA has also released additional plugins under the Eclipse Public License version 2:

  • For some of these plugins, the native libraries of the reader solutions are public, in this case, the plugin can be compiled autonomously.
  • In the opposite case, a mock is used to compensate the unavailability of the native reader library, meaning that it is necessary to contact the manufacturer in order to compile the plugin.

4 plugins are designed for integration into Android based embedded ticketing terminals equipped with a contactless card reader, as well as one or more contact readers for SAMs.

  • The Famoco plugin interfaces only with SAM readers, as the contactless reader on the Famoco supported terminals is based on the standard Android NFC API (natively supported by Keyple).
  • In addition to SAM readers, the Coppernic, Flowbird and Bluebird plug-ins manage an observable contactless reader (capable of detecting the card presence).

The 5th plugin enables a Calypso legacy HSM to be interfaced on a Linux server equipped with a Spirtech HSM.

NameSupported DeviceNative reader library accessibilityInterfaceOSLanguage
CoppernicC-One v2publicInternalAndroidKotlin
FamocoFX100, FX105, FX200, FX205, FX300, FX915, FX920public
FlowbirdAxio Touch Validator/MTBorne validator, Magnetic Axio Touch Validator, Axio 4 Validator, Infigo Driver Console, Voyager Embedded Ticketing Vending Machine, Coppernic C-One, Coppernic C-One V2, Zebra TC77, ACTIA PSDTprivate
BluebirdEF501, EF551private
Legacy HSMSpirtech HSMprivateIPLinuxJava

Some special features:

  • The embedded Android terminals addressed by these plugins only support static configurations for their contactless card and contact SAM readers. However, the Coppernic and Famoco plugins are designed as “observable” plugins, because when these portable terminals are in standby mode, their readers are no longer powered (as if they were unplugged).
  • Most of these readers for embedded terminals are “configurable” to enable the support of specific communications protocols. In addition, the Bluebird plugin can be configured to support the Enhanced Contactless Polling (ECP) protocol specific to Apple NFC devices.
Plugin API implemented interfaces for each pluginCoppernicFamocoFlowbirdBluebirdLegacy
HSM
pluginPluginSpi
ObservablePluginSpi
AutonomousObservablePluginSpi
PoolPluginSpi
contactReaderSpi
ConfigurableReaderSpi
AutonomousSelectionReaderSpi
PoolReaderSpi
contact -lessReaderSpi
ConfigurableReaderSpi
ObservableReaderSpi
CardInsertionWaiterAsynchronousSpi
WaitForCardInsertionAutonomousSpi
CardInsertionWaiterBlockingSpi
WaitForCardInsertionBlockingSpi
CardInsertionWaiterNonBlockingSpi
WaitForCardInsertionNonBlockingSpi
CardRemovalWaiterAsynchronousSpi
WaitForCardRemovalAutonomousSpi
CardRemovalWaiterBlockingSpi
WaitForCardRemovalBlockingSpi
CardRemovalWaiterNonBlockingSpi
WaitForCardRemovalNonBlockingSpi
CardPresenceMonitorBlockingSpi
DontWaitForCardRemovalDuring +On the other hand, for some “contact” reader solutions, card presence is statically defined: these readers don’t need to be observed.

Properties of a smartcard reader solution through the Keyple Service API

For a Keyple-based terminal, smartcard reader solutions are interfaced using reader plug-ins. Keyple’s Service API enables ticketing terminal applications to access “locally” 3 categories of reader solutions:

  • a “simple” plugin enables only static configuration of smartcard readers → the most common case in embedded systems.
  • an “observable” plugin enables the management of reader solutions that can be hot-plugged or hot-disconnected. → mainly 2 uses: readers connected over serial links (e.g. USB), or mobile solutions with an energy-saving mode (reader power supply cut off at standby).
  • a “pool” plugin for interfacing with solutions offering dynamic allocation of reader resources according to the need. → this is how an HSM-type solution works.

Integrating a smartcard reader solution into Keyple through the Plugin API

For a Keyple-based terminal, a dedicated plug-in for any smart card reader solution must implement Keyple’s Plugin API:

  • SPIs are differentiated in particular for the 2 reader types and the 3 plug-in categories.
  • other features are linked to the native API capabilities of reader solutions:
    • autonomy to manage the Select Application command
    • autonomous synchronous, autonomous asynchronous or non-autonomous card insertion detection,
    • detection of card withdrawal at the end of a transaction, managed autonomously (synchronous or asynchronous) or non-autonomous,
    • ability to detect card removal during a card transaction

The Keyple project offers a guide for developing plugins to integrate smartcard reader solutions.

Additional ‘Reader Plugins’ provided by CNA

The Keyple project already hosts several plugins for interfacing with “standard” smartcard reader solutions (PC/SC, Android NFC / OMAPI), or for emulating readers.

To illustrate some other ways of designing plugins, CNA has also released additional plugins under the Eclipse Public License version 2:

  • For some of these plugins, the native libraries of the reader solutions are public, in this case, the plugin can be compiled autonomously.
  • In the opposite case, a mock is used to compensate the unavailability of the native reader library, meaning that it is necessary to contact the manufacturer in order to compile the plugin.

4 plugins are designed for integration into Android based embedded ticketing terminals equipped with a contactless card reader, as well as one or more contact readers for SAMs.

  • The Famoco plugin interfaces only with SAM readers, as the contactless reader on the Famoco supported terminals is based on the standard Android NFC API (natively supported by Keyple).
  • In addition to SAM readers, the Coppernic, Flowbird and Bluebird plug-ins manage an observable contactless reader (capable of detecting the card presence).

The 5th plugin enables a Calypso legacy HSM to be interfaced on a Linux server equipped with a Spirtech HSM.

NameSupported DeviceNative reader library accessibilityInterfaceOSLanguage
CoppernicC-One v2publicInternalAndroidKotlin
FamocoFX100, FX105, FX200, FX205, FX300, FX915, FX920public
FlowbirdAxio Touch Validator/MTBorne validator, Magnetic Axio Touch Validator, Axio 4 Validator, Infigo Driver Console, Voyager Embedded Ticketing Vending Machine, Coppernic C-One, Coppernic C-One V2, Zebra TC77, ACTIA PSDTprivate
BluebirdEF501, EF551private
Legacy HSMSpirtech HSMprivateIPLinuxJava

Some special features:

  • The embedded Android terminals addressed by these plugins only support static configurations for their contactless card and contact SAM readers. However, the Coppernic and Famoco plugins are designed as “observable” plugins, because when these portable terminals are in standby mode, their readers are no longer powered (as if they were unplugged).
  • Most of these readers for embedded terminals are “configurable” to enable the support of specific communications protocols. In addition, the Bluebird plugin can be configured to support the Enhanced Contactless Polling (ECP) protocol specific to Apple NFC devices.
Plugin API implemented interfaces for each pluginCoppernicFamocoFlowbirdBluebirdLegacy
HSM
pluginPluginSpi
ObservablePluginSpi
AutonomousObservablePluginSpi
PoolPluginSpi
contactReaderSpi
ConfigurableReaderSpi
AutonomousSelectionReaderSpi
PoolReaderSpi
contact
-less
ReaderSpi
ConfigurableReaderSpi
ObservableReaderSpi
CardInsertionWaiterAsynchronousSpi
WaitForCardInsertionAutonomousSpi
CardInsertionWaiterBlockingSpi
WaitForCardInsertionBlockingSpi
CardInsertionWaiterNonBlockingSpi
WaitForCardInsertionNonBlockingSpi
CardRemovalWaiterAsynchronousSpi
WaitForCardRemovalAutonomousSpi
CardRemovalWaiterBlockingSpi
WaitForCardRemovalBlockingSpi
CardRemovalWaiterNonBlockingSpi
WaitForCardRemovalNonBlockingSpi
CardPresenceMonitorBlockingSpi
DontWaitForCardRemovalDuring -ProcessingSpi
WaitForCardRemovalDuring -ProcessingBlockingSpi

Published with Hugo Blox Builder — the free, open source website builder that empowers creators.