Skip to content

Frontend Integration

The authentication service provides a JavaScript SDK for integrating authentication into your frontend application. This SDK allows you to trigger the authentication process and handle the authentication response. There are three(3) different options for integrating the authentication service into your frontend application:

  1. Redirect: This option redirects the user to the authentication service's login page, where they can authenticate themselves. After successful authentication, the user is redirected back to your application with the authentication response.

  2. Popup: This option opens a new window for the user to interact with the authentication service. After successful authentication, the window is closed, and the user is redirected back to your application with the authentication response.

  3. Iframe: This option embeds the authentication service's login page in an iframe within your application. After successful authentication, the response is sent to the parent window.

  4. Strip Mode: This option gives you more control over the UI by providing only the authentication form component. Unlike the iframe option, Strip Mode allows you to embed just the authentication form within an existing page, enabling full customization of the rest of the page around the form.

The next section provides a step-by-step guide on how to implement each of these options listed above above in your frontend application.

Important Note

Irrespective of the option you choose, you will need to include the Hubtel Authentication JavaScript SDK file in your code:

For Next.js, add this to the body tag in the root layout file:

javascript
<Script
  src="[BASE_URL]/js/v1/auth.js"
  strategy="beforeInteractive"
/>

After including the SDK in your project, you need to initialize it by creating an instance of the AuthSDK class. Provide your unique application ID when creating the instance.

const authSDK = new AuthSDK(appId, authOptions);

appId: This is the unique application ID you received after registering your application with the authentication service. It is required for redirect and popup options.

authOptions: This is an object that contains additional configuration options for the authentication process. The available options are:

  • redirectUrl: The URL to redirect the user to after successful authentication. This is required when using the redirect option. The redirectUrl must be on the same domain as the referral URL.
  • phoneNumber: The user's phone number. This is required when the user is known and is not required to provide enter their phone number again during the authentication process. This option needs to be activated from the backoffice.

Redirect Option

To trigger the redirect, call the redirect function on the AuthSDK instance. This will open the auth login for the user to authenticate themselves. After successful authentication, the user is redirected back to the redirectUrl with the response appended to the url as query parameters.

javascript
declare const AuthSDK: any;

const Login = () => {
  const handleLogin = () => {
    // replace with your app Id and redirect url (must be absolute)
    const appId = "d998d013-d6f5-4ee9-8059-867bd44f6e52"
    const authSDK = new AuthSDK(appId, { redirectUrl: "http://localhost:3000/redirect" })
    authSDK.redirect()
  }

  return (
    <button onClick={handleLogin} className="btn d-block w-100 btn-outline-primary btn-block mb-3">
      Redirect Login
    </button>
  );
};

export default Login;

Obtaining response from redirect option

After successful authentication, the user will be redirected to the redirectUrl provided prior with the response appended to it:

// Sample URL after redirect
http://localhost:3000/redirect?mobileNumber=233208074263&token=[TOKEN]&expiry=08%2F09%2F2024+13%3A29%3A44&playerId=null&requestId=&email=null&lat=undefined&lng=undefined

Then to retrieve these values in your route component:

javascript
import React, { useEffect, useState } from 'react';

const YourComponent: React.FC = () => {
  const [successResponse, setSuccessResponse] = useState<Record<string, string>>({});

  useEffect(() => {
    const urlParams = new URLSearchParams(window.location.search);
    const paramsObject: Record<string, string> = {};
    urlParams.forEach((value, key) => {
      paramsObject[key] = value;
    });
    setSuccessResponse(paramsObject);
  }, []);

  return (
    <div>Redirect</div>
  );
};

Redirect

redirect page

To trigger the popup, call the popup function on the initialized AuthSDK instance with a success and failure callback.

javascript
declare const AuthSDK: any;

const Login = () => {
  const handleLogin = () => {
    // replace with your app Id and redirect url (must be absolute)
    const appId = "d998d013-d6f5-4ee9-8059-867bd44f6e52"
    const authSDK = new AuthSDK(appId);
    authSDK.popUp(
      (response) => {
          //Put your logic for handling successful login here
            console.log(response);
      },
      (error) => {
        //Put your logic for handling failed login attempt here
        console.log(error);
      }
    );
  }

  return (
    <button onClick={handleLogin} className="btn btn-primary">
      Popup Login
    </button>
  );
};

export default Login;

Popup login

pop up

Iframe Option

To use the iframe option, you need to create an iframe element in your HTML file and set its src attribute to the authentication service's login url with your application ID. If you wish to initialize the iframe with the user's phone number, you can append the phone number as a query parameter to the login url. The iframe option is typically used when you want to embed the login service in an existing page.

html
<iframe
  src="[BASE_URL]/your-app-id?phoneNumber=233456789023"
  title="Authentication"
  style="height: 100%; border: none; width: 100%;"
>
</iframe>

To listen to the response from the iframe, call the listen function on the initialized AuthSDK instance with a success and failure callback.

javascript
import React, { useEffect } from "react";

declare const AuthSDK: any;

// replace with your app Id
const appId = "d998d013-d6f5-4ee9-8059-867bd44f6e52"

const Login = () => {
  useEffect(() => {
    handleLogin();
  }, []);

  const handleLogin = () => {
    const authSDK = new AuthSDK();
    authSDK.listen(
      (response: any) => {
      // Put your logic for handling successful login here
      console.log(response);
      },
      (error: any) => {
        //Put your logic for handling failed login attempt here
        console.log(error);
      }
    );
  };

  return (
    <iframe
      src={`[BASE_URL]/${appId}`}
      title="Hubtel Authentication"
      style={{ height: "100%", border: "none", width: "100%" }}
    />
  );
};

export default Login;

iframe

Strip Mode

To use the strip mode, you need to embed an iframe in your HTML file and set its src attribute to the authentication service's strip mode URL with your application ID. The strip mode is designed to be a compact form that can adjust its height dynamically based on the content, providing a seamless user experience within a fixed-width container.

To handle authentication responses and resize events, use the listen function on the initialized AuthSDK instance with success, error, and resize callbacks.

jsx
import React, { useEffect, useRef, useState } from 'react';

const Login = () => {
  const [iframeHeight, setIframeHeight] = useState(165);
  const [loading, setLoading] = useState(true)

  useEffect(() => {
    const authSdk = new AuthSDK();
    authSdk.listen(
      (success) => {
        // Handle success response
        console.log(success);
      },
      (error) => {
        // Handle error response
        console.log(error);
      },
      (resize) => {
        // Handle Resize Event
        console.log(resize);
        if (resize?.height) {
          setIframeHeight(resize.height);
        }
      },
      (init) => {
        // Handle initialisation event
          setLoading(false);
        }
      }
    );
  }, []);

  return (
    <div style={{ width: '500px', padding: '10px', borderRadius: '10px' }}>
      <iframe
        style={{
          width: '100%',
          border: 'none',
          transition: '0.5s',
          borderRadius: '10px',
          height: `${iframeHeight}px`,
          display: loading ? "none" : "block"
        }}
        title="Hubtel Authentication"
        src="[BASE_URL]/d998d013-d6f5-4ee9-8059-867bd44f6e52/strip"
      />
    </div>
  );
};

export default Login;

Strip Mode

Response Objects

  • Success Response

    The success callback receives a response object with the following structure:

    json
    {
      success: boolean,
      data: {
        mobileNumber: string,
        token: string,
        hasSetPin?: boolean,
        expiry: string
        lat?: string
        lng?: string
      }
    }

    The data object contains details such as the authenticated user's mobile number, token, and token expiry information.

  • Error Response

    The error callback receives an error object with the following structure:

    json
    {
      reason: string;
      code: number;
    }

    The reason field provides a human-readable description of the error or reason for the failure, and the code field represents an error code for programmatic handling.