Skip to main content
Skip table of contents

Features of Smart ID Mobile SDK and Smart ID Mobile App

This article describes key features of the ready-to-use mobile app Smart ID Mobile App and the software development kit Smart ID Mobile SDK, which can be used to implement your own mobile app for authentication and signing. Smart ID Mobile App is entirely based on Smart ID Mobile SDK. 

Both the SDK and the app comes with a complete protocol and interface documentation.

 

Features

Smart ID Mobile SDK

Smart ID Mobile App

Use cases



Activation of mobile virtual smart cards for users, including provisioning of user certificates for authentication, signing, and encryption.

(tick)

(tick)

Authentication to local or web applications.

(tick)

(tick)

Signing transactions.

(tick)

(tick)

Certificate import and renewal.

(tick)

(tick)

Delete mobile virtual smart cards from device, both started from server and local

(tick)

(tick)

SDK app branding



Public keys, certificates and other identity metadata are available to the app.

(tick)

(tick)

Implementer decides which identity and other parameters shall accept or reject the pending request.

(tick)

(tick)

Implementer-specific metadata can accompany any request, for example raw data, text, pdf or images.

(tick)

(tick)

Attestation key can be provided by implementer so that the server can validate that it is your client responding.

(tick)

(tick)

Built-in fingerprint and biometric authentication.

(tick)

(tick)

Registering device and receiving push notifications from Nexus Push Service hosted by Nexus.


(tick)

Hosting your own Nexus Push Service backend server for push notifications.

(tick)


Displaying the SDK licence dependencies.


(tick)

Easy-to-use and intuitive interface.


(tick)

Can be integrated to an existing app

(tick)


Easy to trigger from external applications via app-to-app transitions using the 'personal://' URL-scheme.


(tick)

Built-in mobile device management (MDM) integration. This applies to iOS only.


(tick)

Secure sharing of keys with apps signed by same developer via shared key chain. This applies to iOS only.

(tick)

(tick)

Secure communication



Activation links are only for one-time use, and cannot be reused.

(tick)

(tick)

PIN codes are validated on the server side, to perform flow control and add extra security.

(tick)

(tick)

The identities continue to communicate with the same server that provisioned them.

(tick)

(tick)

Prevention of man-in-the-middle attacks by TLS handshake and server certificate validation in response.

(tick)

(tick)

Possibility to define that specific server certificates are the only ones allowed.

(tick)

(tick)

Attestation key included to make sure that the client is genuinely Nexus.

(tick)

(tick)

Secure key storage



Generates keys on the device and provides proof of possession to the server.

(tick)

(tick)

Key storage is device-bound and non-extractable.

(tick)

(tick)

Protected with obfuscation, root detection, real-time checks and debugger detection.

(tick)

(tick)

Minimum PIN policy is fixed at six digits and disallowing sequences.

(tick)

(tick)

Blocked after wrong PIN attempts for increasing amount of time, until the tenth try when the identity is entirely blocked.

(tick)

(tick)

Lifecycle management



Uses either X.509 certificates or raw key pairs, based on JSON Web Keys, see RFC 7517.

When activating a certificate, a signed PKCS#10 certificate signing request (CSR) is provided for each key in the activation response.

(tick)

(tick)

Renewal of certificates supported, including cryptographic key exchange.

(tick)

(tick)

Secure import of keys is supported:

  • Import keys from the server side, for example for encryption certificates.

  • Import keys to the keystore of the device's operating system.

(tick)

(tick)

Identities can be migrated from one server to another, but keys never leave the device.

(tick)

(tick)

Support for securing OATH tokens for use in offline scenarios, for example with bad internet connection, RADIUS or on airplanes.

(tick)

(tick)

Usability



Uses either Smart ID Digital Access component, Smart ID Identity Manager or Hermod to communicate.

(tick)

(tick)

One server implementation can talk to all our clients: iOS, Android, Windows, Mac, and Linux.

(tick)

(tick)

Possibility to have multiple identities in the SDK simultaneously.

(tick)

(tick)

Support for multiple simultaneous authentication or signing requests.

(tick)

(tick)

Possibility via server trust to login to external servers by trusting the certificate authority (CA).

(tick)

(tick)

Uses standard protocols like HTTPS, JOSE and REST. All keys and crypto are handled within JOSE standard objects.

(tick)

(tick)

Support for Google OTPAUTH protocol. This enables migration from Google and Microsoft Authenticator. Support for user display name in mobile virtual smart cards with OTP for ease-of-use.

(tick)

(tick)

Possibility to secure your existing accounts with two-factor authentication, for example in Google, Visma, Hubspot and Microsoft.

(tick)

(tick)

Cryptographics



Minimum 2048-bit RSA key pairs.

(tick)

(tick)

Signatures use standard JSON Web Algorithms (JWA), either RS256 or RS512.
For more information, see RFC 7518.

(tick)

(tick)

Keys are stored with password-based key derivation and encrypted using Advanced Encryption Standard (AES). Keys use device keystore when available.

(tick)

(tick)

Keys are securely encrypted with multiple layers of AES-256.

(tick)

(tick)

Keys are stored with server-based parameters to increase security in online scenarios.

(tick)

(tick)

Additional information

JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.