Verify Virtual National Identification Number (vNIN)

This endpoint allows you to verify virtual NIN. Youverify Enterprise/Short Code is 471335. Virtual NIN can be generated via the NIMC mobile App or via USSD. Use this link to learn how to generate a Virtual NIN to be verified. You can also use this link to

vNIN Verification

POST {{baseurl}}/v2/api/identity/ng/vnin

Headers

Name
Type
Description

token*

String

API secret token

Request Body

Name
Type
Description

id*

Sting

Valid virtual NIN

isSubjectConsent*

Boolean

Indicate subject has given consent. Must be true

validation

Object

Validation Object

data

Object

Validation Object

lastName

String

lastname to compare against ID

firstName

String

firstname to compare against ID

dateOfBirth

String

date of birth to compare against ID

selfie

Object

Selfie Validation Object

image

String

Selfie image to compare against ID

vNIN Verification

vNIN verification verifies that a provided virtual National Identity Number exists in the database. It shows the full information of the NIN holder;

{
    "id": "YV111111111111FY",
    "isSubjectConsent": true
}
{
    "success": true,
    "statusCode": 200,
    "message": "success",
    "data": {
        "id": "637beef426cb96b1fa6a8d3f",
        "validations": {
            "data": {
                "lastName": {
                    "validated": true,
                    "value": "Citizen"
                },
                "dateOfBirth": {
                    "validated": false,
                    "value": "1988-04-04"
                },
                "firstName": {
                    "validated": true,
                    "value": "Proud"
                }
            },
            "validationMessages": "Date of birth does not match"
        },
        "parentId": null,
        "status": "found",
        "reason": null,
        "dataValidation": true,
        "selfieValidation": false,
        "firstName": "PROUD",
        "middleName": "NIGERIAN",
        "lastName": "CITIZEN",
        "image": "",
        "mobile": "2341234567890",
        "mobileIntFormat": "2341234567890",
        "agentId": "ABCDEF-8910",
        "vNINUserId": "ABCDEF-8910",
        "dateOfBirth": "1960-10-01",
        "vNIN": "YV111111111111FY",
        "isConsent": true,
        "idNumber": "YV111111111111FY",
        "businessId": "6222a5ea3e7a41c29c030fac",
        "type": "vnin",
        "allValidationPassed": false,
        "gender": "male",
        "requestedAt": "2022-11-21T21:34:44.109Z",
        "requestedById": "6222a5ea3e7a41c29c030fad",
        "country": "NG",
        "createdAt": "2022-11-21T21:34:44.124Z",
        "lastModifiedAt": "2022-11-21T21:34:44.124Z",
        "metadata": {},
        "requestedBy": {
            "firstName": "API",
            "lastName": "User",
            "middleName": "",
            "id": "6222a5ea3e7a41c29c030fad"
        }
    },
    "links": []
}

vNIN Facial Matching

vNIN Facial matching is used to verify that a virtual NIN is valid and also that image provided matches with the image in the database. This includes a confidence score of the Facial matching;

{
    "id": "YV111111111111FY",
    "isSubjectConsent": true,
    "validations": {
        "selfie": {
            "image": "https://cdn.youverify.co/1655466566309-lLSfNTlhElMTtbXW-QE-q.jpg"
        }
    }
}
{
    "success": true,
    "statusCode": 200,
    "message": "success",
    "data": {
        "id": "637bed7026cb96881c6a8d36",
        "validations": {
            "selfie": {
                "selfieVerification": {
                    "confidenceLevel": 39,
                    "threshold": 80,
                    "match": false,
                    "image": ""
                }
            },
            "validationMessages": "Provided image does not match ID image"
        },
        "parentId": null,
        "status": "found",
        "reason": null,
        "dataValidation": false,
        "selfieValidation": true,
        "firstName": "PROUD",
        "middleName": "NIGERIAN",
        "lastName": "CITIZEN",
        "image": "",
        "mobile": "2341234567890",
        "mobileIntFormat": "2341234567890",
        "agentId": "ABCDEF-8910",
        "vNINUserId": "ABCDEF-8910",
        "dateOfBirth": "1960-10-01",
        "vNIN": "YV111111111111FY",
        "isConsent": true,
        "idNumber": "YV111111111111FY",
        "businessId": "6222a5ea3e7a41c29c030fac",
        "type": "vnin",
        "allValidationPassed": false,
        "gender": "male",
        "requestedAt": "2022-11-21T21:28:17.953Z",
        "requestedById": "6222a5ea3e7a41c29c030fad",
        "country": "NG",
        "createdAt": "2022-11-21T21:28:17.966Z",
        "lastModifiedAt": "2022-11-21T21:28:17.966Z",
        "metadata": {},
        "requestedBy": {
            "firstName": "API",
            "lastName": "User",
            "middleName": "",
            "id": "6222a5ea3e7a41c29c030fad"
        }
    },
    "links": []
}

vNIN Validation

vNIN Validation verifies a virtual NIN and compares given data parameters against the data present in the database. For example, a first name and last name can be provided and this will validate as true or false as to whether it matches with the names in the database or not;

    "id": "YV111111111111FY",
    "isSubjectConsent": true,
    "validations": {
        "data": {
            "lastName": "Doe",
            "firstName": "Sarah",
            "dateOfBirth": "1988-04-04"
        }
    }
}
{
    "success": true,
    "statusCode": 200,
    "message": "success",
    "data": {
        "id": "637beef426cb96b1fa6a8d3f",
        "validations": {
            "data": {
                "lastName": {
                    "validated": true,
                    "value": "Citizen"
                },
                "dateOfBirth": {
                    "validated": false,
                    "value": "1988-04-04"
                },
                "firstName": {
                    "validated": true,
                    "value": "Proud"
                }
            },
            "validationMessages": "Date of birth does not match"
        },
        "parentId": null,
        "status": "found",
        "reason": null,
        "dataValidation": true,
        "selfieValidation": false,
        "firstName": "PROUD",
        "middleName": "NIGERIAN",
        "lastName": "CITIZEN",
        "image": "",
        "mobile": "2341234567890",
        "mobileIntFormat": "2341234567890",
        "agentId": "ABCDEF-8910",
        "vNINUserId": "ABCDEF-8910",
        "dateOfBirth": "1960-10-01",
        "vNIN": "YV111111111111FY",
        "isConsent": true,
        "idNumber": "YV111111111111FY",
        "businessId": "6222a5ea3e7a41c29c030fac",
        "type": "vnin",
        "allValidationPassed": false,
        "gender": "male",
        "requestedAt": "2022-11-21T21:34:44.109Z",
        "requestedById": "6222a5ea3e7a41c29c030fad",
        "country": "NG",
        "createdAt": "2022-11-21T21:34:44.124Z",
        "lastModifiedAt": "2022-11-21T21:34:44.124Z",
        "metadata": {},
        "requestedBy": {
            "firstName": "API",
            "lastName": "User",
            "middleName": "",
            "id": "6222a5ea3e7a41c29c030fad"
        }
    },
    "links": []
}

vNIN Full Sample Request

This is a sample request that contains all the parameters as described above, all in one call

{
    "id": "YV111111111111FY",
    "metadata": {
        "requestId": "1209348756"
},
    "isSubjectConsent": true,
    "validations": {
        "data": {
            "lastName": "Citizen",
            "firstName": "Proud",
            "dateOfBirth": "1988-04-04"
        },
        "selfie": {
            "image": "https://cdn.youverify.co/1655466566309-lLSfNTlhElMTtbXW-QE-q.jpg"
        }
    }
}
{
    "success": true,
    "statusCode": 200,
    "message": "success",
    "data": {
        "id": "637bf00726cb966fed6a8d43",
        "validations": {
            "data": {
                "lastName": {
                    "validated": true,
                    "value": "Citizen"
                },
                "dateOfBirth": {
                    "validated": false,
                    "value": "1988-04-04"
                },
                "firstName": {
                    "validated": true,
                    "value": "Proud"
                }
            },
            "selfie": {
                "selfieVerification": {
                    "confidenceLevel": 39,
                    "threshold": 80,
                    "match": false,
                    "image": ""
                }
            },
            "validationMessages": "Date of birth does not match, Provided image does not match ID image"
        },
        "parentId": null,
        "status": "found",
        "reason": null,
        "dataValidation": true,
        "selfieValidation": true,
        "firstName": "PROUD",
        "middleName": "NIGERIAN",
        "lastName": "CITIZEN",
        "image": "",
        "mobile": "2341234567890",
        "mobileIntFormat": "2341234567890",
        "agentId": "ABCDEF-8910",
        "vNINUserId": "ABCDEF-8910",
        "dateOfBirth": "1960-10-01",
        "vNIN": "YV111111111111FY",
        "isConsent": true,
        "idNumber": "YV111111111111FY",
        "businessId": "6222a5ea3e7a41c29c030fac",
        "type": "vnin",
        "allValidationPassed": false,
        "gender": "male",
        "requestedAt": "2022-11-21T21:39:20.516Z",
        "requestedById": "6222a5ea3e7a41c29c030fad",
        "country": "NG",
        "createdAt": "2022-11-21T21:39:20.534Z",
        "lastModifiedAt": "2022-11-21T21:39:20.534Z",
        "metadata": {
            "requestId": "1209348756"
        },
        "requestedBy": {
            "firstName": "API",
            "lastName": "User",
            "middleName": "",
            "id": "6222a5ea3e7a41c29c030fad"
        }
    },
    "links": []
}
HTTP/1.1 402 Payment Required
  {
    "success": false,
    "statusCode": 402,
    "message": "Insufficient fund",
    "name": "PaymentRequiredError",
    "data": {}
}


HTTP/1.1 500 Internal Server Error
{
    "success": false,
    "statusCode": 500,
    "message": "Service unavailable",
    "name": "Error",
    "data": {}
}

HTTP/1.1 403 Forbidden
{
    "success": false,
    "statusCode": 403,
    "message": "Permission denied",
    "name": "UnauthorizedError",
    "data": {}
}

Last updated