In the context of Open eCard App, the terms add-on, plug-in and extension are defined as follows.
Add-on is the generic term for a component that enhances the functionality of the Open eCard App.
Extensions are independent from the context. Moreover, they are included directly into
the user interface and can be executed by the user. For instance, an add-on that provides a
PIN change functionality for smart cards is classified as an extension.
Plug-ins depend on the context in which the user uses the application. Performing
an authentication to a service using a particular smart card, for instance, requires a plug-in
which is capable of providing such functionality. Subsequently, plug-ins require a communication
with bindings to interact with external applications and services. Furthermore,
we distinguish between IFD, SAL, and application plug-ins.
This section describes the steps to take when developing an add-on.
As first step a new XML file called Addon.xml in the META-INF directory of the project should be created and the fields that describe the general part of the add-ons can already be filled.
An example file for a PIN Management addon could look like this:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <AddonBundleDescription> <ID>PIN-Plugin</ID> <Version>1.0</Version> <About /> <License /> <LocalizedName xml:lang="DE">PIN Verwaltung</LocalizedName> <LocalizedDescription xml:lang="DE">Verwaltung von PIN/ PUK und gegebenenfalls anderen Geheimnissen der Chipkarte. </LocalizedDescription> <LocalizedName xml:lang="EN">PIN Management</LocalizedName> <LocalizedDescription xml:lang="EN">Management of PIN/ PUK and possibly other secrets of the smart-card.</LocalizedDescription> <Logo>images/logo.png</Logo> <ConfigDescription /> <BindingActions /> <ApplicationActions /> <IFDActions /> <SALActions /> </AddonBundleDescription>
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <AddonBundleDescription> <ID>PIN-Plugin</ID> <Version>1.0</Version> <About /> <License /> <LocalizedName xml:lang="DE">PIN Verwaltung</LocalizedName> <LocalizedDescription xml:lang="DE">Verwaltung von PIN/ PUK und gegebenenfalls anderen Geheimnissen der Chipkarte. </LocalizedDescription> <LocalizedName xml:lang="EN">PIN Management</LocalizedName> <LocalizedDescription xml:lang="EN">Management of PIN/ PUK and possibly other secrets of the smart-card.</LocalizedDescription> <Logo>images/pin-management.png</Logo> <ConfigDescription /> <BindingActions /> <ApplicationActions> <AppExtensionActionDescription> <ID>ChangePINAction</ID> <ClassName>org.openecard.plugins.pinplugin.ChangePINAction</ClassName> <LocalizedName xml:lang="DE">PIN ändern</LocalizedName> <LocalizedDescription xml:lang="DE">Mit dieser Aktion können Sie ihre PIN ändern.</LocalizedDescription> <LocalizedName xml:lang="EN">Change PIN</LocalizedName> <LocalizedDescription xml:lang="EN">With this action you can change your PIN.</LocalizedDescription> <ConfigDescription /> </AppExtensionActionDescription> <AppExtensionActionDescription> <ID>UnblockPINAction</ID> <ClassName>org.openecard.plugins.pinplugin.UnblockPINAction</ClassName> <LocalizedName xml:lang="DE">PIN entsperren</LocalizedName> <LocalizedDescription xml:lang="DE">Mit dieser Aktion können Sie ihre PIN entsperren.</LocalizedDescription> <LocalizedName xml:lang="EN">Unblock PIN</LocalizedName> <LocalizedDescription xml:lang="EN">With this action you can unblock your PIN.</LocalizedDescription> <ConfigDescription /> </AppExtensionActionDescription> </ApplicationActions> <IFDActions /> <SALActions /> </AddonBundleDescription>For the actual implementation part of the add-on, the following has to be considered.