UNPKG

iq-validator

Version:

An intelligent string validator with configurable sanitisation options.

132 lines (112 loc) 5.82 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _assert = require('assert'); var assert = _interopRequireWildcard(_assert); var _SanitiseRules = require('./SanitiseRules'); var _SanitiseRules2 = _interopRequireDefault(_SanitiseRules); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } /** * IqValidator is an intelligent string validator with built-in configurable * sanitisation capabilities. * The main purpose of IqValidator is to provide an easy and configurable * way to sanitise big string datasets (for example coming from different * databases or from un-validated spreadsheet exports). * It allows to specifiy a main regular expression which is used to determine * if a specific string is valid or it needs sanitisation. * In the second case, the user can specify an array of sanitisation rules each of them * defined in form of javascript objects. A rule is composed by a regex plus some * regex flags (see RegExp javascript object docs) and a function which has the purpose * of perfom some kind of string maniupulation as an attempt to sanitise (reformat) * the invalid string. * When a string passed to the sanitise method is evaluated to invalid, the algorithm * will loop through the array of possible sanitisation rules and check if the invalid * string matches the rule's regular expression. * At this point 3 scenarios can happen: * 1. One matching sanitisation rule found: * In this case, the sanitisation function is invoked passing the invalid string as * parameter. The function is expected to return a string which passes the main regular * expression * 2. More than one matching sanitisation rules found. This shouldn't happen, in this case * only the first matching sanitisation function is run. * 3. No matching sanitisation rule found: * In this case null is returned */ var IqValidator = function () { /** * @summary Create an instance of IqValidator * @name IqValidator * @class * @public * * @param {RegExp} mainRegex - A RegExp object used for validation * @param {Array} sanitiseRules - an array of objects with the following format * { * regex: 'regex', * regexFlags: 'ig', * sanitiseFunction: function(str) { * //do sanitisation * return str; * } * } * @throws {AssertionError} If the argument/s is/are invalid. */ function IqValidator(mainRegex, sanitiseRules) { _classCallCheck(this, IqValidator); assert.equal(mainRegex instanceof RegExp, true, 'argument \'mainRegex\' must be a RegExp object'); this.mainRegex = mainRegex; this.sanitiseRules = new _SanitiseRules2.default(sanitiseRules); } /** * @summary Tests a given string against the mainRegex regex to check if it's valid * @method * @private * * @param {string} str - the string to test against the mainRegex regex * @returns {boolean} true if the argument matches the mainRegex * @throws {AssertionError} If the argument is invalid. */ _createClass(IqValidator, [{ key: 'isValid', value: function isValid(str) { return this.mainRegex.test(str); } /** * @summary Tests the validity of the string passed as argument. If the string is invalid and * some sanitisation rules have been specified, it runs through them trying to sanitise the * string. Finally, if the sanitised string passes the mainRegex validation, it is returned, * otherwise null is returned. * @method * @public * * @param {string} str - the string to validate/sanitise * @returns {string|null} A string is returned if either the str parameter is valid or if one of * the sanitising functions have been able to make the string valid. Null is returned otherwise * @throws {AssertionError} If the argument is invalid. */ }, { key: 'sanitise', value: function sanitise(str) { assert.equal(typeof str === 'undefined' ? 'undefined' : _typeof(str), 'string', 'argument \'str\' must be a string'); if (this.isValid(str)) { return str; } var matchingRules = this.sanitiseRules.getMatchingRules(str); for (var i = 0; i < matchingRules.length; i += 1) { var sanitisedStr = matchingRules[i].runSanitise(str); if (this.isValid(sanitisedStr)) { return sanitisedStr; } } return null; } }]); return IqValidator; }(); exports.default = IqValidator; module.exports = exports['default'];