Secure Element: Accessing Secure Elements
This tutorial demonstrates how you can access and manage secure elements in a device.
The Secure Element API is optional for both Tizen mobile and wearable profiles, which means that it may not be supported in all mobile and wearable devices. The Secure Element API is supported on all Tizen Emulators.
Warm-up
Become familiar with the Secure Element API basics by learning about:
-
Managing Secure Elements
Retrieve all available secure element readers, and track changes in the available readers.
-
Opening Sessions and Channels
Open a session, and then a basic and logical channel within the session.
-
Transmitting APDUs to Secure Elements
Transmit an application protocol data units (APDU) command to a secure element.
-
Closing Sessions and Channels
Close specific channels and sessions, or all channels and sessions.
Managing Secure Elements
To use secure elements in your application, you must learn to retrieve them and track changes in them:
-
To retrieve all the available secure element readers, use the getReaders() method of the SEService interface (in mobile and wearable applications). The method registers the ReaderArraySuccessCallback interface (in mobile and wearable applications), which is invoked when the list of available secure element readers has been successfully retrieved.
function success(readers) { for (var i = 0; i < readers.length; i++) { if (readers[i].isPresent) console.log("Reader Name: " + readers[i].getName()); } } tizen.seService.getReaders(success, function(err) {/* Error handling */});
-
To receive reader change notifications, use the registerSEListener() method of the SEService interface:
-
Define a listener using the SEChangeListener interface (in mobile and wearable applications):
var setSEChange = { onSEReady: function(reader) { console.log(reader.getName() + " is ready."); }, onSENotReady: function(reader) { console.log(reader.getName() + " is not ready."); }, }
-
Register the listener:
var seListener = tizen.seService.registerSEListener(setSEChange);
-
-
To stop listening to the reader changes, use the unregisterSEListener() method:
tizen.seService.unregisterSEListener(seListener);
Opening Sessions and Channels
To use secure elements in your application, you must learn to open sessions and channels:
-
To open a session, use the openSession() method of the Reader interface (in mobile and wearable applications). The method registers the SessionSuccessCallback interface (in mobile and wearable applications), which is invoked when a session on a specific reader is opened.
function successCB(session) { console.log("A session is open successfully"); } function errorCB(err) { /* Error handling */ } reader.openSession(successCB, errorCB);
-
To open a channel within a session:
-
Open a basic channel with the openBasicChannel() method of the Session interface (in mobile and wearable applications). The method registers the ChannelSuccessCallback interface (in mobile and wearable applications), which is invoked when a channel is opened to communicate with a specific applet.
function successCB(channel) { if (channel.isBasicChannel) console.log("A basic channel is opened successfully"); else console.log("A logical channel is opened successfully"); } function errorCB(err) { /* Error handling */ } /* This aid is for testing purposes for your applet */ session.openBasicChannel([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe], successCB, errorCB);
-
Open a logical channel with the openLogicalChannel() method of the Session interface. As with a basic channel, the method registers the ChannelSuccessCallback interface.
session.openLogicalChannel([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe], successCB, errorCB);
-
Transmitting APDUs to Secure Elements
To use secure elements in your application, you must learn to transmit application protocol data units (APDU) to secure elements:
-
To transmit an APDU command to a secure element, use the transmit() method of the Channel interface (in mobile and wearable applications).
/* The APDU command is defined in ISO7816-4 */ channel.transmit(command, successCB, errorCB);
-
The transmit() method registers the TransmitSuccessCallback interface (in mobile and wearable applications), which is invoked when a command has been successfully transmitted:
function successCB(response) { console.log("An APDU is transmitted successfully. The response is " + response); } function errorCB(err) { /* Error handling */ }
Closing Sessions and Channels
To use secure elements in your application, you must learn to close sessions and channels:
-
To close a specific channel, use the close() method of the Channel interface (in mobile and wearable applications):
channel.close();
-
To close all channels within a specific session, use the closeChannels() method of the Session interface (in mobile and wearable applications):
session.closeChannels();
-
To close a specific session, use the close() method of the Session interface:
session.close();
-
To close all session for a specific reader, use the closeSessions() method of the Reader interface (in mobile and wearable applications):
reader.closeSessions();