Using Web SDK

The IDWise JavaScript Document Capture SDK provides a convenient way to integrate the IDWise Digital Identity Verification technology into your web application. With minimal effort, you can incorporate a highly customisable user interface (UI) that guides users through a series of steps, prompting them for their ID documents and/or biometrics based on your configured journey flow in the IDWise backend system. Upon completion of the process, your app receives a callback with information about the finished journey, allowing your backend code to securely retrieve the journey results. It's that simple!

Comparing IDWise Web SDK with the Native SDK

The IDWise Web SDK offers a comprehensive feature set that aligns closely with the capabilities of our Native SDK. However, there are a few key differences to consider:

  • Smart Capture Capabilities: The Web SDK does not currently support advanced Smart Capture features, such as automatic document capture and automatic selfie capture, which are available in the Native SDK.
  • Dynamic SDK: The Dynamic SDK feature is not available in the web version.

Full Integration Sequence Diagram

Here is a sequence diagram illustrating the steps performed after integrating the SDK with your mobile app or web application

SDK Usage

Ensure you have first added Web SDK to your project by following the steps in this page WebSDK Installation

Follow these steps to integrate the document capturing SDK:

Initialize the SDK

Initialize the IDWise SDK library using the initialize function. This function requires the following parameters:

  • clientKey (Mandatory): A string that identifies your business and is used for authentication. Provided by the IDWise team.
  • locale (Optional): A two-letter ISO language identifier (e.g., "en") to determine the language of the UI. The default is "en". Contact the IDWise team to enable support for different languages.
  • theme (Optional): The theme of UI elements, which can be either light or dark. Alternatively, use system_default for the system default theme.

The initialize function returns a promise that resolves to a session instance. This session instance is used to access the functionality of the IDWise system in the subsequent steps.

Example code for initialization:

 <script>
     let idwise;
     IDWise.initialize({
        //replace xxxx with client key that you have generated from API Keys section in admin panel 
        clientKey: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
        locale: "en",
     })
     .then(result => {
        idwise = result
     })
     .catch(error => {
        alert(error);
     });
  </script>

Starting a new Journey

Use the IDWise session instance obtained from the initialize function to start a new journey by calling the startJourney function. This function requires the following parameters:

  • flowId (Mandatory): A string that identifies the journey flow to be started. Provided by the IDWise team based on your requirements.

  • mount (Mandatory): A string with a CSS selector representing a single element. This specifies the HTML DOM element where IDWise UI elements should be added.

  • referenceNo (Optional but recommended): A string used to uniquely identify the user undergoing the journey in your system. This identifier will be attached to the journey and can be used to link the journey back to your system when fetching the journey data.

  • applicantDetails (Optional) This parameter allows you to pass applicant details which is Information about the person doing the verification. This is usually the information that the user fills in your registration form before doing the KYC process. If you don't want to pass any applicant details then you can just pass null.

  • eventHandlers (Optional but recommended): An object containing call-backs to handle different events fired by the IDWise SDK. The supported call-backs include:

    1. onJourneyStarted: Triggered when the user starts the journey.

      FieldTypeDescription
      journeyIdStringThe value of the field
    2. onJourneyResumed: Triggered when the user resumes the journey.

      FieldTypeDescription
      journeyIdStringThe value of the field
    3. onJourneyFinished: Triggered when the user completes all the steps of the journey.

      FieldTypeDescription
      journeyIdStringThe value of the field
    4. onJourneyCancelled: Triggered when the user cancels the journey.

      FieldTypeDescription
      journeyIdStringThe value of the field
    5. onError : Triggered when the user is not able to continue the journey due to a breaking error.

      FieldTypeDescription
      codeStringError code specifying the type of error that occurred. Please refer to this page for details on possible error codes https://docs.idwise.com/docs/sdk-error-codes
      messageStringMessage explaining the error
      requestIdStringUnique identifier for this request. Please keep track of this identifier as it is useful to share with IDWise Support when making any support requests

Example code for start journey:

 let applicantDetails = {
   "full_name": "John Doe",
   "birth_date": "1995-05-06",
   "sex": "male",
 };

idwise.startJourney({
   flowId: 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx', 
   mount: '#idwise-mount',
   applicantDetails: applicantDetails,
   referenceNo: "842098029309823", 
   eventHandlers: {
   onJourneyStarted: function(details) {
     // You should keep track of details.journeyId and store it in your DB for this applicant
   },
   onJourneyFinished: function(details) {
     // By this point UI control is back to your app and IDWise UI is now removed
     // No further steps are required from your user for KYC at this point
     // The journey processing will continue in the background
     // You can inform your user that their submission was received and that you will get back to them with the outcome
     // Your backend can listen to IDWise Webhooks or poll IDWise backend to know when the results are ready
     // When the journey processing is done you can inform the user of next steps you require from them based on the journey decision
   },
   onJourneyCancelled: function(details) {
     // By this point UI control is back to your app and IDWise UI is now removed
     // You can inform your user that their KYC was interrupted and not finished yet
     // and that they need to come back to finish it
   },
   onError: function(details) {
     // Check the details.code to identify the reason of the error
     // Read details.message for further details explaining the error
     // Log any errors in your system logs and ensure you log all the elements in details object    
   },
 }
});

The journeyId identifier can be used to retrieve the data associated with the journey from the IDWise Data Fetch API once you receive the Journey Finished webhook in your backend.

Note that the IDWise SDK automatically removes the IDWise UI and cleans up the used resources when a journey completes.

That's it! You have successfully completed the core integration and enabled streamlined user onboarding journeys using the IDWise Web SDK. You can find here a sample HTML file that demonstrates the integration steps described above.

WebSDK Desktop Transitioning Options

When embedding the WebSDK into a web application accessed from a desktop, you can configure the transitioning behavior using the Flow Builder with one of the following options:

  • Switch to mobile web to complete the verification (Recommended):
    Redirects users to the mobile web by displaying a QR code on the desktop for scanning. This is the recommended option for ensuring optimal performance and capturing high-quality images.
  • Continue on desktop:
    Allows users to complete the process on the desktop by uploading files or using the desktop camera. Note: Desktop cameras often have lower resolution, which could impact verification quality.
  • Let the user choose desktop or mobile web:
    Offers users the choice to either remain on the desktop or transition to the mobile web for verification, accommodating individual preferences.

Resuming a Journey

To resume a journey, call the resumeJourney function on the IDWise session instance. This function requires the following parameters:

  • flowId (Mandatory): A string that identifies the journey flow to be started. Provided by the IDWise team based on your requirements.
  • mount (Mandatory): A string with a CSS selector representing a single element. This specifies the HTML DOM element where IDWise UI elements should be added.
  • journeyId (Mandatory): An id string that is received after starting a journey on one of the eventHandlers in startJourney function.
  • eventHandlers (Optional but recommended): An object containing call-backs to handle different events fired by the IDWise SDK. These are explained in Starting a new Journey section above.

This is an example code snippet of how your invocation of resumeJourney will look like:

idwise.resumeJourney({
   flowId: 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx', 
   mount: '#idwise-mount',
   journeyId: "xxxxxxxxxxxxxxxx", 
   eventHandlers: {
   onJourneyResumed: function(details) {
     // This confirms the journey was resumed successfully and UI control is with IDWise SDK
     // IDWise will guide the user to complete the progress on this existing journey
   },
   onJourneyFinished: function(details) {
     // By this point UI control is back to your app and IDWise UI is now removed
     // No further steps are required from your user for KYC at this point
     // The journey processing will continue in the background
     // You can inform your user that their submission was received and that you will get back to them with the outcome
     // Your backend can listen to IDWise Webhooks or poll IDWise backend to know when the results are ready
     // When the journey processing is done you can inform the user of next steps you require from them based on the journey decision
   },
   onJourneyCancelled: function(details) {
     // By this point UI control is back to your app and IDWise UI is now removed
     // You can inform your user that their KYC was interrupted and not finished yet
     // and that they need to come back to finish it
   },
   onError: function(details) {
     // Check the details.code to identify the reason of the error
     // Read details.message for further details explaining the error
     // Log any errors in your system logs and ensure you log all the elements in details object    
   }
 }
});

Cancelling the Journey

To cancel a journey, call the cleanup function on the IDWise session instance. This function takes no parameters and returns a promise. The promise is resolved when the journey is cancelled and the UI elements are removed

<script>
 let idwise;
 IDWise.initialize({
    //replace xxxx with client key that you have generated from API Keys section in admin panel 
    clientKey: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
    locale: "en",
 })
 .then(result => {
    idwise = result
  	// Starts the journey
  	idwise.startJourney({ ... });
 })
 .catch(error => {
   	// Handle initialization error
  });

  .
  .
  .
  
  // To cancel IDWise process at any moment and hide IDWise UI you can invoke this method
  idwise.cleanup();
</script>

Triggering IDWise SDK Again

If the IDWise SDK has an active journey (initiated by calling startJourney or resumeJourney) and you wish to switch to a different journey within the same script without reloading the web page, it is essential to clean up the current active journey. This ensures that the IDWise SDK can properly handle the new journey.

To do this clean up you can call cleanup method on the IDWise session instance. The following code shows an example:

<script>
 let idwise;
 IDWise.initialize({
    //replace xxxx with client key that you have generated from API Keys section in admin panel 
    clientKey: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
    locale: "en",
 })
 .then(result => {
    idwise = result
    // Starts the journey first time in this session
    idwise.startJourney({ ... });
 })
 .catch(error => {
   	// Handle initialization error
  });

  .
  .
  .
  
  // Use this method to trigger another journey in same session
  // cleanup is necessary to clean the state of the current journey and ensure IDWise SDK is ready to handle another journey
  idwise.cleanup();
  idwise.startJourney({ ... });
</script>