Source: Passport-Reader.js

var exec = require("cordova/exec");

var PLUGIN_NAME = "PassportReaderPlugin";

/** @module passportreader */

/** 
 * Basic Access Control (BAC) specification
 * @typedef BACSpec
 * @type {object}
 * @property {string} documentNumber Passport number
 * @property {string} dateOfBirth Date of birth of the passport holder in YYYY-MM-DD format
 * @property {string} dateOfExpiry Passport's date of expiry in YYYY-MM-DD format
 */

/**
 * Passport scan result
 * @typedef ScanResult
 * @type {object}
 * @property {string} documentCode Document code
 * @property {string} issuingState Issuing state
 * @property {string} primaryIdentifier Primary identifier (e.g., last name)
 * @property {Array<string>} secondaryIdentifiers Secondary identifiers (e.g., given names)
 * @property {string} nationality Nationality of the passport holder
 * @property {string} documentNumber Document number
 * @property {string} personalNumber Personal number
 * @property {string} dateOfBirth Date of birth of the passport holder YYYY-MM-DD
 * @property {string} gender Gender of the passport holder
 * @property {string} dateOfExpiry Date of expiry of the passport YYYY-MM-DD
 * @property {string} image Image of the holder's face as URL data scheme (e.g., )
 */

/** 
 * Called when passport scan finishes
 * @callback PassportScanCallback
 * @param {module:passportreader~ScanResult} result Result may be undefined or null if the user cancels the scan
 */

/**
 * Scan a biometric passport and return the data extracted from its NFC chip
 * @param {module:passportreader~BACSpec} bacSpec BAC spec
 * @param {module:passportreader~PassportScanCallback} [callback] Called when passport scan finishes
 * @param {function} [errorCallback] Called when passport scan fails
 * @returns {Promise.<module:passportreader~ScanResult>} If callback is not specified returns a promise
 */
module.exports.scanPassport = function(bacSpec, callback, errorCallback) {
    var args = [{"bacSpec":JSON.stringify(bacSpec)}];
    function parseResult(cb) {
        return function(json) {
            if (json) {
                var result = JSON.parse(json);
                cb(result);
            } else {
                cb();
            }
        }
    }
    if (callback) {
        exec(parseResult(callback), errorCallback, PLUGIN_NAME, "scanPassport", args);
    } else {
        return new Promise(function(resolve, reject) {
            exec(parseResult(resolve), reject, PLUGIN_NAME, "scanPassport", args);
        });
    }
}