Integration of provisioning for multi-device licensing (MDL) authenticators
OneSpan Cloud Authentication supports offline and online provisioning to activate a multi-device licensing (MDL) OneSpan licensing model with a one-to-one relationship between a user account and an authenticator serial number license. With this licensing model, a user account can be optionally bound to several authenticator instances. Multi-Device Activation, which is an activation process in two steps, guarantess that only the intended user can perform the device activation. authenticator.
Offline MDL authenticator provisioning
For offline MDL authenticator provisioning, the integration method depends on whether Activation Message 1 For multi-device activation (MDA) of authenticators: The first activation message. It allows to activate an authenticator license in the device. It may be used several times to allow activation of multiple authenticator instances (of one authenticator license) on multiple authenticator devices if necessary. (generated by OneSpan Cloud Authentication) and the device code (generated on the client side) are generated before the registration session or as part of it.
Prerequisites
Before you integrate offline MDL authenticator provisioning, ensure that the following prerequisites are met:
- The user account is created (via the PUT /users/{userID@domain} endpoint)
- A static user password is set
- An MDL authenticator license is assigned to the user (via the POST /users/{userID@domain}/assign endpoint)
To integrate offline MDL authenticator provisioning when the device code has already been generated
- (OneSpan Cloud Authentication) Generate Activation Message 1 via the POST /authenticators/{serialNumber}/generate-activation-message endpoint from the response.
- (Optional) (OneSpan Cloud Authentication) If required, generate a Cronto Specific colorful cryptogram, similar to a QR code that is used for visual transaction signing. message from the activation message via the GET /visualcodes/render endpoint.
- (Client) Based on the received activation message, activate the MDL license and generate the device code.
-
(OneSpan Cloud Authentication) Initiate a registration session via the POST /registrations endpoint. The following input fields and field values are mandatory:
- activationType: offlineMDL
- userID
- staticPassword
- deviceCode
Retrieve registrationID and activationMessage2 from the response.
- (Optional) (OneSpan Cloud Authentication) If required, generate a Cronto message from Activation Message 2 For multi-device activation (MDA) of authenticators: The first activation message. It allows to activate an authenticator license in the device. It may be used several times to allow activation of multiple authenticator instances (of one authenticator license) on multiple authenticator devices if necessary. via the GET /visualcodes/render endpoint.
- (Client) Based on the received Activation Message 2, activate the MDL instance and generate a signature.
-
(OneSpan Cloud Authentication) Activate the authenticator instance via the POST /registrations/{registrationID}/activate endpoint. The following input is mandatory:
- signature
To integrate offline MDL authenticator provisioning with device code generation during the registration session
-
(OneSpan Cloud Authentication) Initiate a registration session via the POST /registrations endpoint. The following input fields and field values are mandatory:
- activationType: offlineMDL
- userID
- staticPassword
Retrieve registrationID and activationMessage from the response.
- (Optional) (OneSpan Cloud Authentication) If required, generate a Cronto message from the activation message via the GET /visualcodes/render endpoint.
- (Client) Based on the received activation message, activate the MDL license and generate the device code.
- (OneSpan Cloud Authentication) Confirm the activation of the license via the POST /registrations/{registrationID}/add-device endpoint. The following input field is mandatory:
- deviceCode
Retrieve activationMessage2 from the response.
- (Optional) (OneSpan Cloud Authentication) If required, generate a Cronto message from the activationMessage2 via the GET /visualcodes/render endpoint.
- (Client) Based on the received Activation Message 2, activate the MDL instance and generate a signature.
-
(OneSpan Cloud Authentication) Activate the authenticator instance via the POST /registrations/{registrationID}/activate endpoint. The following input is mandatory:
- signature
Online MDLauthenticator provisioning
With online MDL provisioning, the required DSAPP DIGIPASS Software Advanced Provisioning Protocol. A protocol that is used to securely transfer the server-side generated authenticator software activation data to the authenticator software client.-SRP Secure Remote Password protocol. With this protocol, the secret shared between the server and the client - the user password - is not transmitted via the network. operations are available through the OneSpan Trusted Identity platform API. During the activation process, an authenticator instance is created.
Prerequisites
Before you integrate online MDL authenticator provisioning, ensure that the following prerequisites are met:
- An authenticator license is available
- The user account is created (via the PUT /users/{userID@domain} endpoint)
- A static user password is set
- An MDL authenticator license is assigned to the user (via the POST /users/{userID@domain}/assign endpoint)
Sequence of an online MDL authenticator provisioning flow
- The user initiates the online provisioning process on the client web application and enters a user ID and a static password.
- The Authentication component creates a provisioning session with the user ID and generates the activation password and the request ID.
- The client server verifies the registration ID and the activation password and calls the Visual Code service for a Cronto image to be generated.
- The user scans the Cronto image. This establishes the offline communication channel.
- To secure the online communication between the mobile application and OneSpan Cloud Authentication, the mobile application generates the client ephemeral key.
Based on the client ephemeral key, the server ephemeral key is generated via the POST /registrations/{registrationID}/generate-ephemeral-key endpoint. Mandatory input for this operation to succeed:- clientEphemeralKey
- The Provisioning Service receives the client ephemeral key and returns the server ephemeral key and a salt.
- The mobile application reads this and requests the activation message via the POST /registrations/{registrationID}/generate-activation-message endpoint.
- The mobile application receives Activation Message 1 For multi-device activation (MDA) of authenticators: The first activation message. It allows to activate an authenticator license in the device. It may be used several times to allow activation of multiple authenticator instances (of one authenticator license) on multiple authenticator devices if necessary., uses it to activate the authenticator license, and generates a device code.
- The device code is used as input for the /registrations/{registrationID}/add-device endpoint. This endpoint adds and/or assigns the authenticator instance to the user account and generates Activation Message 2 For multi-device activation (MDA) of authenticators: The second activation message. It allows to activate an authenticator instance of a license on the device. It can be used for the effective activation of one authenticator instance only..
- The mobile device uses Activation Message 2 to activate the authenticator instance and generates a signature to finalize the registration process via the POST /registrations/{registrationID}/activate endpoint.
To integrate the online MDL provisioning flow
- Start the online provisioning process with a DSAPP-SRP registration via the POST /registrations endpoint.
Payload:
- staticPassword
- activationType
- (Optional) domain
- (Optional) serialNumber
Response payload:
- activationPassword
- registrationID
- serialNumber
-
To secure the online communication between the mobile application and OneSpan Cloud Authentication, generate an ephemeral key (DSAPP-SRP) via the POST /registrations/{registrationID}/generate-ephemeral-key endpoint.
-
Payload:
- clientEphemeralPublicKey
-
Response payload:
- Salt
- serverEphemeralPublicKey
-
Failure responses:
- 400: The input is invalid.
- 404: The registration session was not found.
- 409: Incorrect activation type.
- 500: Unexpected server error.
-
-
Generate the activation message via the POST /registrations/{registrationID}/generate-activation-message endpoint.
-
Payload:
- clientEvidenceMessage
-
Response payload:
- activationMessage.encryptedData
- activationMessage.encryptionCounter
- activationMessage.MAC
- serverEvidenceMessage
-
Failure responses:
- 400: The input is invalid.
- 404: The registration session was not found.
- 409: Incorrect activation type or authenticator does not support activation.
- 500: Unexpected server error.
-
-
Add an MDL device via the POST /registrations/{registrationID}/add-device endpoint.
-
Payload:
- deviceCode
-
Response payload:
- activationMessage2
- activationType
- deviceStatus
- deviceType
- domain
- registrationID
- serialNumber
- userID
-
-
Activate MDL via the POST /registrations/{registrationID}/activate endpoint.
-
Payload:
- signature
-
Response payload:
- userID
- domain
- serialNumber
-
-
(Optional) Update the device Push Notification Identifier (PNID) via the POST /users/{userID@domain}/authenticators/{serialNumber}/update-pnid endpoint.
-
Payload:
- encryptedMessage
-
Failure responses:
- 400: The input is invalid.
- 404: The user account or authenticator was not found.
- 409: Failed to update the PNID for the authenticator.
- 500: Unexpected server error.
-