Giter Site home page Giter Site logo

nodejs-library's Introduction

Vereafy

A Node JS package for Cecula Vereafy.

Build Status

Table of Content

  1. Introduction
  2. How to use the library
  3. Installation
  4. How to generate an API Key
  5. Importing Vereafy Library
  6. Initializating 2FA
  7. Resending OTP
  8. Completing 2FA
  9. Getting Balance
  10. Error Responses

Introduction

Vereafy is an SMS based 2-factor authentication service that uses machine learning to understand the causes of OTP delivery failures and resolves them instantly to ensure your login and sign up OTPs deliver.

The Vereafy Nodejs Library Project was created to enable nodejs developers integrate seamlessly with the Vereafy API.

How to use this library

  • Install vereafy from npm or yarn following the instructions in the Installation section or clone from GitHub
  • Login to the Cecula Developers Platform register your app and generate an API KEY
  • Import/Require the library into your script

Installation

Install with NPM:

npm i vereafy

Install with Yarn:

yarn add vereafy

Clone from GitHub

git clone https://github.com/cecula-vereafy/nodejs-library.git

How to generate an API Key

Your API Key is first generated when you register an app. To register an app, Login to the Developers Dashboard, Navigate to Apps > Add, Type the name of your app and click Submit. The app will be registered and a new API Key will be generated. Copy the API key into your project

Importing Vereafy Library

If you installed the library using npm or yarn, import the library into your script using the code below

const vereafy = require("vereafy");
vereafy.apiKey = "<API_KEY>"

Otherwise, if you cloned the library from GitHub, import the library into your script using the code below

const vereafy = require("./path/to/vereafy");
vereafy.apiKey = "<API_KEY>"

Initializing 2FA

The Vereafy 2fa initialization can be as simple as the following lines of code:

    var sendData = {
        "mobile": "23480xxxxxxxx"
    };

    vereafy.init(senData,(res)=>{
        // If status is success show user form to type OTP
    });

The initialization method returns a response that should look like this:

   {
       "status": "success",
       "pinRef": "1293488527"
   }

Resending OTP

In a case where your app users get impatient and hits the retry link on your app form, just call the resend method this way:

   var sendData = {
       "pinRef": "1293488527",
       "mobile": "23480xxxxxxxx"
   };

   vereafy.resend(sendData, (res)=>{
       // If status is success, show user form to type OTP
   });

The resend method returns a response that should look like this:

    {
        "status": "success",
        "pinRef": "1293488527"
    }

Completing 2FA

The Vereafy 2fa completion can be as simple as the following lines of code:

    var sendData = {
        "pinRef": "1293488527",
        "token": "123456"
    }
    vereafy.complete(sendData, (res)=>{
        // Handle failure or success response
    })

The completion method returns a response that should look like this if the parameters are correct:

    {
        "response": "success"
    }

Getting Balance

To get your balance on Vereafy, the getBalance method is used this way: This method requires no parameter:

    vereafy.getBalance((res)=>{
        // Do Something
    })

The get balance method returns a response that should look like:

    {
        "balance": 800
    }

Error Responses

In a case where the request fails due to one reason or another you should get an error response from the requested endpoint that looks like this:

        {
            "error": "Invalid PIN Ref",
            "code": "CE2000"
        }

The table below shows a list of error codes and their descriptions:

Error Code Description
CE1001 Missing Fields
CE1002 Empty Fields
CE1006 Not a Nigerian Number
CE2000 Invalid PIN Ref
CE2002 PIN does not reference any verification request
CE2003 Mobile number does not match original request
CE2001 Invalid PIN
CE2004 Request Not Found
CE7000 Verification already succeeded
CE7001 Verification already failed
CE6000 Insufficient Balance
CE5000 Invalid Template ID
CE5001 Could not find referenced template

nodejs-library's People

Contributors

bbnplace avatar tuoyoclinton avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.