|
@@ -0,0 +1,1356 @@
|
|
|
+function _extends() {
|
|
|
+ _extends = Object.assign || function(target) {
|
|
|
+ for (var i = 1; i < arguments.length; i++) {
|
|
|
+ var source = arguments[i];
|
|
|
+
|
|
|
+ for (var key in source) {
|
|
|
+ if (Object.prototype.hasOwnProperty.call(source, key)) {
|
|
|
+ target[key] = source[key];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return target;
|
|
|
+ };
|
|
|
+
|
|
|
+ return _extends.apply(this, arguments);
|
|
|
+}
|
|
|
+
|
|
|
+/* eslint no-console:0 */
|
|
|
+var formatRegExp = /%[sdj%]/g;
|
|
|
+var warning = function warning() {}; // don't print warning message when in production env or node runtime
|
|
|
+
|
|
|
+if (typeof process !== 'undefined' && process.env && process.env.NODE_ENV !== 'production' && typeof window !==
|
|
|
+ 'undefined' && typeof document !== 'undefined') {
|
|
|
+ warning = function warning(type, errors) {
|
|
|
+ if (typeof console !== 'undefined' && console.warn) {
|
|
|
+ if (errors.every(function(e) {
|
|
|
+ return typeof e === 'string';
|
|
|
+ })) {
|
|
|
+ console.warn(type, errors);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ };
|
|
|
+}
|
|
|
+
|
|
|
+function convertFieldsError(errors) {
|
|
|
+ if (!errors || !errors.length) return null;
|
|
|
+ var fields = {};
|
|
|
+ errors.forEach(function(error) {
|
|
|
+ var field = error.field;
|
|
|
+ fields[field] = fields[field] || [];
|
|
|
+ fields[field].push(error);
|
|
|
+ });
|
|
|
+ return fields;
|
|
|
+}
|
|
|
+
|
|
|
+function format() {
|
|
|
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
|
+ args[_key] = arguments[_key];
|
|
|
+ }
|
|
|
+
|
|
|
+ var i = 1;
|
|
|
+ var f = args[0];
|
|
|
+ var len = args.length;
|
|
|
+
|
|
|
+ if (typeof f === 'function') {
|
|
|
+ return f.apply(null, args.slice(1));
|
|
|
+ }
|
|
|
+
|
|
|
+ if (typeof f === 'string') {
|
|
|
+ var str = String(f).replace(formatRegExp, function(x) {
|
|
|
+ if (x === '%%') {
|
|
|
+ return '%';
|
|
|
+ }
|
|
|
+
|
|
|
+ if (i >= len) {
|
|
|
+ return x;
|
|
|
+ }
|
|
|
+
|
|
|
+ switch (x) {
|
|
|
+ case '%s':
|
|
|
+ return String(args[i++]);
|
|
|
+
|
|
|
+ case '%d':
|
|
|
+ return Number(args[i++]);
|
|
|
+
|
|
|
+ case '%j':
|
|
|
+ try {
|
|
|
+ return JSON.stringify(args[i++]);
|
|
|
+ } catch (_) {
|
|
|
+ return '[Circular]';
|
|
|
+ }
|
|
|
+
|
|
|
+ break;
|
|
|
+
|
|
|
+ default:
|
|
|
+ return x;
|
|
|
+ }
|
|
|
+ });
|
|
|
+
|
|
|
+ for (var arg = args[i]; i < len; arg = args[++i]) {
|
|
|
+ str += " " + arg;
|
|
|
+ }
|
|
|
+
|
|
|
+ return str;
|
|
|
+ }
|
|
|
+
|
|
|
+ return f;
|
|
|
+}
|
|
|
+
|
|
|
+function isNativeStringType(type) {
|
|
|
+ return type === 'string' || type === 'url' || type === 'hex' || type === 'email' || type === 'pattern';
|
|
|
+}
|
|
|
+
|
|
|
+function isEmptyValue(value, type) {
|
|
|
+ if (value === undefined || value === null) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (type === 'array' && Array.isArray(value) && !value.length) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (isNativeStringType(type) && typeof value === 'string' && !value) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+ return false;
|
|
|
+}
|
|
|
+
|
|
|
+function asyncParallelArray(arr, func, callback) {
|
|
|
+ var results = [];
|
|
|
+ var total = 0;
|
|
|
+ var arrLength = arr.length;
|
|
|
+
|
|
|
+ function count(errors) {
|
|
|
+ results.push.apply(results, errors);
|
|
|
+ total++;
|
|
|
+
|
|
|
+ if (total === arrLength) {
|
|
|
+ callback(results);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ arr.forEach(function(a) {
|
|
|
+ func(a, count);
|
|
|
+ });
|
|
|
+}
|
|
|
+
|
|
|
+function asyncSerialArray(arr, func, callback) {
|
|
|
+ var index = 0;
|
|
|
+ var arrLength = arr.length;
|
|
|
+
|
|
|
+ function next(errors) {
|
|
|
+ if (errors && errors.length) {
|
|
|
+ callback(errors);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ var original = index;
|
|
|
+ index = index + 1;
|
|
|
+
|
|
|
+ if (original < arrLength) {
|
|
|
+ func(arr[original], next);
|
|
|
+ } else {
|
|
|
+ callback([]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ next([]);
|
|
|
+}
|
|
|
+
|
|
|
+function flattenObjArr(objArr) {
|
|
|
+ var ret = [];
|
|
|
+ Object.keys(objArr).forEach(function(k) {
|
|
|
+ ret.push.apply(ret, objArr[k]);
|
|
|
+ });
|
|
|
+ return ret;
|
|
|
+}
|
|
|
+
|
|
|
+function asyncMap(objArr, option, func, callback) {
|
|
|
+ if (option.first) {
|
|
|
+ var _pending = new Promise(function(resolve, reject) {
|
|
|
+ var next = function next(errors) {
|
|
|
+ callback(errors);
|
|
|
+ return errors.length ? reject({
|
|
|
+ errors: errors,
|
|
|
+ fields: convertFieldsError(errors)
|
|
|
+ }) : resolve();
|
|
|
+ };
|
|
|
+
|
|
|
+ var flattenArr = flattenObjArr(objArr);
|
|
|
+ asyncSerialArray(flattenArr, func, next);
|
|
|
+ });
|
|
|
+
|
|
|
+ _pending["catch"](function(e) {
|
|
|
+ return e;
|
|
|
+ });
|
|
|
+
|
|
|
+ return _pending;
|
|
|
+ }
|
|
|
+
|
|
|
+ var firstFields = option.firstFields || [];
|
|
|
+
|
|
|
+ if (firstFields === true) {
|
|
|
+ firstFields = Object.keys(objArr);
|
|
|
+ }
|
|
|
+
|
|
|
+ var objArrKeys = Object.keys(objArr);
|
|
|
+ var objArrLength = objArrKeys.length;
|
|
|
+ var total = 0;
|
|
|
+ var results = [];
|
|
|
+ var pending = new Promise(function(resolve, reject) {
|
|
|
+ var next = function next(errors) {
|
|
|
+ results.push.apply(results, errors);
|
|
|
+ total++;
|
|
|
+
|
|
|
+ if (total === objArrLength) {
|
|
|
+ callback(results);
|
|
|
+ return results.length ? reject({
|
|
|
+ errors: results,
|
|
|
+ fields: convertFieldsError(results)
|
|
|
+ }) : resolve();
|
|
|
+ }
|
|
|
+ };
|
|
|
+
|
|
|
+ if (!objArrKeys.length) {
|
|
|
+ callback(results);
|
|
|
+ resolve();
|
|
|
+ }
|
|
|
+
|
|
|
+ objArrKeys.forEach(function(key) {
|
|
|
+ var arr = objArr[key];
|
|
|
+
|
|
|
+ if (firstFields.indexOf(key) !== -1) {
|
|
|
+ asyncSerialArray(arr, func, next);
|
|
|
+ } else {
|
|
|
+ asyncParallelArray(arr, func, next);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ });
|
|
|
+ pending["catch"](function(e) {
|
|
|
+ return e;
|
|
|
+ });
|
|
|
+ return pending;
|
|
|
+}
|
|
|
+
|
|
|
+function complementError(rule) {
|
|
|
+ return function(oe) {
|
|
|
+ if (oe && oe.message) {
|
|
|
+ oe.field = oe.field || rule.fullField;
|
|
|
+ return oe;
|
|
|
+ }
|
|
|
+
|
|
|
+ return {
|
|
|
+ message: typeof oe === 'function' ? oe() : oe,
|
|
|
+ field: oe.field || rule.fullField
|
|
|
+ };
|
|
|
+ };
|
|
|
+}
|
|
|
+
|
|
|
+function deepMerge(target, source) {
|
|
|
+ if (source) {
|
|
|
+ for (var s in source) {
|
|
|
+ if (source.hasOwnProperty(s)) {
|
|
|
+ var value = source[s];
|
|
|
+
|
|
|
+ if (typeof value === 'object' && typeof target[s] === 'object') {
|
|
|
+ target[s] = _extends({}, target[s], {}, value);
|
|
|
+ } else {
|
|
|
+ target[s] = value;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return target;
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Rule for validating required fields.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param errors An array of errors that this rule may add
|
|
|
+ * validation errors to.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function required(rule, value, source, errors, options, type) {
|
|
|
+ if (rule.required && (!source.hasOwnProperty(rule.field) || isEmptyValue(value, type || rule.type))) {
|
|
|
+ errors.push(format(options.messages.required, rule.fullField));
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Rule for validating whitespace.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param errors An array of errors that this rule may add
|
|
|
+ * validation errors to.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function whitespace(rule, value, source, errors, options) {
|
|
|
+ if (/^\s+$/.test(value) || value === '') {
|
|
|
+ errors.push(format(options.messages.whitespace, rule.fullField));
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/* eslint max-len:0 */
|
|
|
+
|
|
|
+var pattern = {
|
|
|
+ // http://emailregex.com/
|
|
|
+ email: /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
|
|
|
+ url: new RegExp(
|
|
|
+ "^(?!mailto:)(?:(?:http|https|ftp)://|//)(?:\\S+(?::\\S*)?@)?(?:(?:(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[0-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z\\u00a1-\\uffff0-9]+-*)*[a-z\\u00a1-\\uffff0-9]+)(?:\\.(?:[a-z\\u00a1-\\uffff0-9]+-*)*[a-z\\u00a1-\\uffff0-9]+)*(?:\\.(?:[a-z\\u00a1-\\uffff]{2,})))|localhost)(?::\\d{2,5})?(?:(/|\\?|#)[^\\s]*)?$",
|
|
|
+ 'i'),
|
|
|
+ hex: /^#?([a-f0-9]{6}|[a-f0-9]{3})$/i
|
|
|
+};
|
|
|
+var types = {
|
|
|
+ integer: function integer(value) {
|
|
|
+ return types.number(value) && parseInt(value, 10) === value;
|
|
|
+ },
|
|
|
+ "float": function float(value) {
|
|
|
+ return types.number(value) && !types.integer(value);
|
|
|
+ },
|
|
|
+ array: function array(value) {
|
|
|
+ return Array.isArray(value);
|
|
|
+ },
|
|
|
+ regexp: function regexp(value) {
|
|
|
+ if (value instanceof RegExp) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+ try {
|
|
|
+ return !!new RegExp(value);
|
|
|
+ } catch (e) {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ },
|
|
|
+ date: function date(value) {
|
|
|
+ return typeof value.getTime === 'function' && typeof value.getMonth === 'function' && typeof value.getYear ===
|
|
|
+ 'function';
|
|
|
+ },
|
|
|
+ number: function number(value) {
|
|
|
+ if (isNaN(value)) {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
+ // 修改源码,将字符串数值先转为数值
|
|
|
+ return typeof +value === 'number';
|
|
|
+ },
|
|
|
+ object: function object(value) {
|
|
|
+ return typeof value === 'object' && !types.array(value);
|
|
|
+ },
|
|
|
+ method: function method(value) {
|
|
|
+ return typeof value === 'function';
|
|
|
+ },
|
|
|
+ email: function email(value) {
|
|
|
+ return typeof value === 'string' && !!value.match(pattern.email) && value.length < 255;
|
|
|
+ },
|
|
|
+ url: function url(value) {
|
|
|
+ return typeof value === 'string' && !!value.match(pattern.url);
|
|
|
+ },
|
|
|
+ hex: function hex(value) {
|
|
|
+ return typeof value === 'string' && !!value.match(pattern.hex);
|
|
|
+ }
|
|
|
+};
|
|
|
+/**
|
|
|
+ * Rule for validating the type of a value.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param errors An array of errors that this rule may add
|
|
|
+ * validation errors to.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function type(rule, value, source, errors, options) {
|
|
|
+ if (rule.required && value === undefined) {
|
|
|
+ required(rule, value, source, errors, options);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ var custom = ['integer', 'float', 'array', 'regexp', 'object', 'method', 'email', 'number', 'date', 'url', 'hex'];
|
|
|
+ var ruleType = rule.type;
|
|
|
+
|
|
|
+ if (custom.indexOf(ruleType) > -1) {
|
|
|
+ if (!types[ruleType](value)) {
|
|
|
+ errors.push(format(options.messages.types[ruleType], rule.fullField, rule.type));
|
|
|
+ } // straight typeof check
|
|
|
+
|
|
|
+ } else if (ruleType && typeof value !== rule.type) {
|
|
|
+ errors.push(format(options.messages.types[ruleType], rule.fullField, rule.type));
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Rule for validating minimum and maximum allowed values.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param errors An array of errors that this rule may add
|
|
|
+ * validation errors to.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function range(rule, value, source, errors, options) {
|
|
|
+ var len = typeof rule.len === 'number';
|
|
|
+ var min = typeof rule.min === 'number';
|
|
|
+ var max = typeof rule.max === 'number'; // 正则匹配码点范围从U+010000一直到U+10FFFF的文字(补充平面Supplementary Plane)
|
|
|
+
|
|
|
+ var spRegexp = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g;
|
|
|
+ var val = value;
|
|
|
+ var key = null;
|
|
|
+ var num = typeof value === 'number';
|
|
|
+ var str = typeof value === 'string';
|
|
|
+ var arr = Array.isArray(value);
|
|
|
+
|
|
|
+ if (num) {
|
|
|
+ key = 'number';
|
|
|
+ } else if (str) {
|
|
|
+ key = 'string';
|
|
|
+ } else if (arr) {
|
|
|
+ key = 'array';
|
|
|
+ } // if the value is not of a supported type for range validation
|
|
|
+ // the validation rule rule should use the
|
|
|
+ // type property to also test for a particular type
|
|
|
+
|
|
|
+
|
|
|
+ if (!key) {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (arr) {
|
|
|
+ val = value.length;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (str) {
|
|
|
+ // 处理码点大于U+010000的文字length属性不准确的bug,如"𠮷𠮷𠮷".length !== 3
|
|
|
+ val = value.replace(spRegexp, '_').length;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (len) {
|
|
|
+ if (val !== rule.len) {
|
|
|
+ errors.push(format(options.messages[key].len, rule.fullField, rule.len));
|
|
|
+ }
|
|
|
+ } else if (min && !max && val < rule.min) {
|
|
|
+ errors.push(format(options.messages[key].min, rule.fullField, rule.min));
|
|
|
+ } else if (max && !min && val > rule.max) {
|
|
|
+ errors.push(format(options.messages[key].max, rule.fullField, rule.max));
|
|
|
+ } else if (min && max && (val < rule.min || val > rule.max)) {
|
|
|
+ errors.push(format(options.messages[key].range, rule.fullField, rule.min, rule.max));
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+var ENUM = 'enum';
|
|
|
+/**
|
|
|
+ * Rule for validating a value exists in an enumerable list.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param errors An array of errors that this rule may add
|
|
|
+ * validation errors to.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function enumerable(rule, value, source, errors, options) {
|
|
|
+ rule[ENUM] = Array.isArray(rule[ENUM]) ? rule[ENUM] : [];
|
|
|
+
|
|
|
+ if (rule[ENUM].indexOf(value) === -1) {
|
|
|
+ errors.push(format(options.messages[ENUM], rule.fullField, rule[ENUM].join(', ')));
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Rule for validating a regular expression pattern.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param errors An array of errors that this rule may add
|
|
|
+ * validation errors to.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function pattern$1(rule, value, source, errors, options) {
|
|
|
+ if (rule.pattern) {
|
|
|
+ if (rule.pattern instanceof RegExp) {
|
|
|
+ // if a RegExp instance is passed, reset `lastIndex` in case its `global`
|
|
|
+ // flag is accidentally set to `true`, which in a validation scenario
|
|
|
+ // is not necessary and the result might be misleading
|
|
|
+ rule.pattern.lastIndex = 0;
|
|
|
+
|
|
|
+ if (!rule.pattern.test(value)) {
|
|
|
+ errors.push(format(options.messages.pattern.mismatch, rule.fullField, value, rule.pattern));
|
|
|
+ }
|
|
|
+ } else if (typeof rule.pattern === 'string') {
|
|
|
+ var _pattern = new RegExp(rule.pattern);
|
|
|
+
|
|
|
+ if (!_pattern.test(value)) {
|
|
|
+ errors.push(format(options.messages.pattern.mismatch, rule.fullField, value, rule.pattern));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+var rules = {
|
|
|
+ required: required,
|
|
|
+ whitespace: whitespace,
|
|
|
+ type: type,
|
|
|
+ range: range,
|
|
|
+ "enum": enumerable,
|
|
|
+ pattern: pattern$1
|
|
|
+};
|
|
|
+
|
|
|
+/**
|
|
|
+ * Performs validation for string types.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function string(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value, 'string') && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options, 'string');
|
|
|
+
|
|
|
+ if (!isEmptyValue(value, 'string')) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ rules.range(rule, value, source, errors, options);
|
|
|
+ rules.pattern(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (rule.whitespace === true) {
|
|
|
+ rules.whitespace(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates a function.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function method(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (value !== undefined) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates a number.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function number(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (value === '') {
|
|
|
+ value = undefined;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (value !== undefined) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ rules.range(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates a boolean.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function _boolean(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (value !== undefined) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates the regular expression type.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function regexp(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (!isEmptyValue(value)) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates a number is an integer.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function integer(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (value !== undefined) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ rules.range(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates a number is a floating point number.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function floatFn(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (value !== undefined) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ rules.range(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates an array.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function array(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value, 'array') && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options, 'array');
|
|
|
+
|
|
|
+ if (!isEmptyValue(value, 'array')) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ rules.range(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates an object.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function object(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (value !== undefined) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+var ENUM$1 = 'enum';
|
|
|
+/**
|
|
|
+ * Validates an enumerable list.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function enumerable$1(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (value !== undefined) {
|
|
|
+ rules[ENUM$1](rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Validates a regular expression pattern.
|
|
|
+ *
|
|
|
+ * Performs validation when a rule only contains
|
|
|
+ * a pattern property but is not declared as a string type.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function pattern$2(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value, 'string') && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (!isEmptyValue(value, 'string')) {
|
|
|
+ rules.pattern(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+function date(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+
|
|
|
+ if (!isEmptyValue(value)) {
|
|
|
+ var dateObject;
|
|
|
+
|
|
|
+ if (typeof value === 'number') {
|
|
|
+ dateObject = new Date(value);
|
|
|
+ } else {
|
|
|
+ dateObject = value;
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.type(rule, dateObject, source, errors, options);
|
|
|
+
|
|
|
+ if (dateObject) {
|
|
|
+ rules.range(rule, dateObject.getTime(), source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+function required$1(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var type = Array.isArray(value) ? 'array' : typeof value;
|
|
|
+ rules.required(rule, value, source, errors, options, type);
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+function type$1(rule, value, callback, source, options) {
|
|
|
+ var ruleType = rule.type;
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value, ruleType) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options, ruleType);
|
|
|
+
|
|
|
+ if (!isEmptyValue(value, ruleType)) {
|
|
|
+ rules.type(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * Performs validation for any type.
|
|
|
+ *
|
|
|
+ * @param rule The validation rule.
|
|
|
+ * @param value The value of the field on the source object.
|
|
|
+ * @param callback The callback function.
|
|
|
+ * @param source The source object being validated.
|
|
|
+ * @param options The validation options.
|
|
|
+ * @param options.messages The validation messages.
|
|
|
+ */
|
|
|
+
|
|
|
+function any(rule, value, callback, source, options) {
|
|
|
+ var errors = [];
|
|
|
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
|
|
|
+
|
|
|
+ if (validate) {
|
|
|
+ if (isEmptyValue(value) && !rule.required) {
|
|
|
+ return callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ rules.required(rule, value, source, errors, options);
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors);
|
|
|
+}
|
|
|
+
|
|
|
+var validators = {
|
|
|
+ string: string,
|
|
|
+ method: method,
|
|
|
+ number: number,
|
|
|
+ "boolean": _boolean,
|
|
|
+ regexp: regexp,
|
|
|
+ integer: integer,
|
|
|
+ "float": floatFn,
|
|
|
+ array: array,
|
|
|
+ object: object,
|
|
|
+ "enum": enumerable$1,
|
|
|
+ pattern: pattern$2,
|
|
|
+ date: date,
|
|
|
+ url: type$1,
|
|
|
+ hex: type$1,
|
|
|
+ email: type$1,
|
|
|
+ required: required$1,
|
|
|
+ any: any
|
|
|
+};
|
|
|
+
|
|
|
+function newMessages() {
|
|
|
+ return {
|
|
|
+ "default": 'Validation error on field %s',
|
|
|
+ required: '%s is required',
|
|
|
+ "enum": '%s must be one of %s',
|
|
|
+ whitespace: '%s cannot be empty',
|
|
|
+ date: {
|
|
|
+ format: '%s date %s is invalid for format %s',
|
|
|
+ parse: '%s date could not be parsed, %s is invalid ',
|
|
|
+ invalid: '%s date %s is invalid'
|
|
|
+ },
|
|
|
+ types: {
|
|
|
+ string: '%s is not a %s',
|
|
|
+ method: '%s is not a %s (function)',
|
|
|
+ array: '%s is not an %s',
|
|
|
+ object: '%s is not an %s',
|
|
|
+ number: '%s is not a %s',
|
|
|
+ date: '%s is not a %s',
|
|
|
+ "boolean": '%s is not a %s',
|
|
|
+ integer: '%s is not an %s',
|
|
|
+ "float": '%s is not a %s',
|
|
|
+ regexp: '%s is not a valid %s',
|
|
|
+ email: '%s is not a valid %s',
|
|
|
+ url: '%s is not a valid %s',
|
|
|
+ hex: '%s is not a valid %s'
|
|
|
+ },
|
|
|
+ string: {
|
|
|
+ len: '%s must be exactly %s characters',
|
|
|
+ min: '%s must be at least %s characters',
|
|
|
+ max: '%s cannot be longer than %s characters',
|
|
|
+ range: '%s must be between %s and %s characters'
|
|
|
+ },
|
|
|
+ number: {
|
|
|
+ len: '%s must equal %s',
|
|
|
+ min: '%s cannot be less than %s',
|
|
|
+ max: '%s cannot be greater than %s',
|
|
|
+ range: '%s must be between %s and %s'
|
|
|
+ },
|
|
|
+ array: {
|
|
|
+ len: '%s must be exactly %s in length',
|
|
|
+ min: '%s cannot be less than %s in length',
|
|
|
+ max: '%s cannot be greater than %s in length',
|
|
|
+ range: '%s must be between %s and %s in length'
|
|
|
+ },
|
|
|
+ pattern: {
|
|
|
+ mismatch: '%s value %s does not match pattern %s'
|
|
|
+ },
|
|
|
+ clone: function clone() {
|
|
|
+ var cloned = JSON.parse(JSON.stringify(this));
|
|
|
+ cloned.clone = this.clone;
|
|
|
+ return cloned;
|
|
|
+ }
|
|
|
+ };
|
|
|
+}
|
|
|
+var messages = newMessages();
|
|
|
+
|
|
|
+/**
|
|
|
+ * Encapsulates a validation schema.
|
|
|
+ *
|
|
|
+ * @param descriptor An object declaring validation rules
|
|
|
+ * for this schema.
|
|
|
+ */
|
|
|
+
|
|
|
+function Schema(descriptor) {
|
|
|
+ this.rules = null;
|
|
|
+ this._messages = messages;
|
|
|
+ this.define(descriptor);
|
|
|
+}
|
|
|
+
|
|
|
+Schema.prototype = {
|
|
|
+ messages: function messages(_messages) {
|
|
|
+ if (_messages) {
|
|
|
+ this._messages = deepMerge(newMessages(), _messages);
|
|
|
+ }
|
|
|
+
|
|
|
+ return this._messages;
|
|
|
+ },
|
|
|
+ define: function define(rules) {
|
|
|
+ if (!rules) {
|
|
|
+ throw new Error('Cannot configure a schema with no rules');
|
|
|
+ }
|
|
|
+
|
|
|
+ if (typeof rules !== 'object' || Array.isArray(rules)) {
|
|
|
+ throw new Error('Rules must be an object');
|
|
|
+ }
|
|
|
+
|
|
|
+ this.rules = {};
|
|
|
+ var z;
|
|
|
+ var item;
|
|
|
+
|
|
|
+ for (z in rules) {
|
|
|
+ if (rules.hasOwnProperty(z)) {
|
|
|
+ item = rules[z];
|
|
|
+ this.rules[z] = Array.isArray(item) ? item : [item];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ },
|
|
|
+ validate: function validate(source_, o, oc) {
|
|
|
+ var _this = this;
|
|
|
+
|
|
|
+ if (o === void 0) {
|
|
|
+ o = {};
|
|
|
+ }
|
|
|
+
|
|
|
+ if (oc === void 0) {
|
|
|
+ oc = function oc() {};
|
|
|
+ }
|
|
|
+
|
|
|
+ var source = source_;
|
|
|
+ var options = o;
|
|
|
+ var callback = oc;
|
|
|
+
|
|
|
+ if (typeof options === 'function') {
|
|
|
+ callback = options;
|
|
|
+ options = {};
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!this.rules || Object.keys(this.rules).length === 0) {
|
|
|
+ if (callback) {
|
|
|
+ callback();
|
|
|
+ }
|
|
|
+
|
|
|
+ return Promise.resolve();
|
|
|
+ }
|
|
|
+
|
|
|
+ function complete(results) {
|
|
|
+ var i;
|
|
|
+ var errors = [];
|
|
|
+ var fields = {};
|
|
|
+
|
|
|
+ function add(e) {
|
|
|
+ if (Array.isArray(e)) {
|
|
|
+ var _errors;
|
|
|
+
|
|
|
+ errors = (_errors = errors).concat.apply(_errors, e);
|
|
|
+ } else {
|
|
|
+ errors.push(e);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ for (i = 0; i < results.length; i++) {
|
|
|
+ add(results[i]);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!errors.length) {
|
|
|
+ errors = null;
|
|
|
+ fields = null;
|
|
|
+ } else {
|
|
|
+ fields = convertFieldsError(errors);
|
|
|
+ }
|
|
|
+
|
|
|
+ callback(errors, fields);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (options.messages) {
|
|
|
+ var messages$1 = this.messages();
|
|
|
+
|
|
|
+ if (messages$1 === messages) {
|
|
|
+ messages$1 = newMessages();
|
|
|
+ }
|
|
|
+
|
|
|
+ deepMerge(messages$1, options.messages);
|
|
|
+ options.messages = messages$1;
|
|
|
+ } else {
|
|
|
+ options.messages = this.messages();
|
|
|
+ }
|
|
|
+
|
|
|
+ var arr;
|
|
|
+ var value;
|
|
|
+ var series = {};
|
|
|
+ var keys = options.keys || Object.keys(this.rules);
|
|
|
+ keys.forEach(function(z) {
|
|
|
+ arr = _this.rules[z];
|
|
|
+ value = source[z];
|
|
|
+ arr.forEach(function(r) {
|
|
|
+ var rule = r;
|
|
|
+
|
|
|
+ if (typeof rule.transform === 'function') {
|
|
|
+ if (source === source_) {
|
|
|
+ source = _extends({}, source);
|
|
|
+ }
|
|
|
+
|
|
|
+ value = source[z] = rule.transform(value);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (typeof rule === 'function') {
|
|
|
+ rule = {
|
|
|
+ validator: rule
|
|
|
+ };
|
|
|
+ } else {
|
|
|
+ rule = _extends({}, rule);
|
|
|
+ }
|
|
|
+
|
|
|
+ rule.validator = _this.getValidationMethod(rule);
|
|
|
+ rule.field = z;
|
|
|
+ rule.fullField = rule.fullField || z;
|
|
|
+ rule.type = _this.getType(rule);
|
|
|
+
|
|
|
+ if (!rule.validator) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ series[z] = series[z] || [];
|
|
|
+ series[z].push({
|
|
|
+ rule: rule,
|
|
|
+ value: value,
|
|
|
+ source: source,
|
|
|
+ field: z
|
|
|
+ });
|
|
|
+ });
|
|
|
+ });
|
|
|
+ var errorFields = {};
|
|
|
+ return asyncMap(series, options, function(data, doIt) {
|
|
|
+ var rule = data.rule;
|
|
|
+ var deep = (rule.type === 'object' || rule.type === 'array') && (typeof rule.fields === 'object' || typeof rule.defaultField ===
|
|
|
+ 'object');
|
|
|
+ deep = deep && (rule.required || !rule.required && data.value);
|
|
|
+ rule.field = data.field;
|
|
|
+
|
|
|
+ function addFullfield(key, schema) {
|
|
|
+ return _extends({}, schema, {
|
|
|
+ fullField: rule.fullField + "." + key
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ function cb(e) {
|
|
|
+ if (e === void 0) {
|
|
|
+ e = [];
|
|
|
+ }
|
|
|
+
|
|
|
+ var errors = e;
|
|
|
+
|
|
|
+ if (!Array.isArray(errors)) {
|
|
|
+ errors = [errors];
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!options.suppressWarning && errors.length) {
|
|
|
+ Schema.warning('async-validator:', errors);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (errors.length && rule.message) {
|
|
|
+ errors = [].concat(rule.message);
|
|
|
+ }
|
|
|
+
|
|
|
+ errors = errors.map(complementError(rule));
|
|
|
+
|
|
|
+ if (options.first && errors.length) {
|
|
|
+ errorFields[rule.field] = 1;
|
|
|
+ return doIt(errors);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!deep) {
|
|
|
+ doIt(errors);
|
|
|
+ } else {
|
|
|
+ // if rule is required but the target object
|
|
|
+ // does not exist fail at the rule level and don't
|
|
|
+ // go deeper
|
|
|
+ if (rule.required && !data.value) {
|
|
|
+ if (rule.message) {
|
|
|
+ errors = [].concat(rule.message).map(complementError(rule));
|
|
|
+ } else if (options.error) {
|
|
|
+ errors = [options.error(rule, format(options.messages.required, rule.field))];
|
|
|
+ } else {
|
|
|
+ errors = [];
|
|
|
+ }
|
|
|
+
|
|
|
+ return doIt(errors);
|
|
|
+ }
|
|
|
+
|
|
|
+ var fieldsSchema = {};
|
|
|
+
|
|
|
+ if (rule.defaultField) {
|
|
|
+ for (var k in data.value) {
|
|
|
+ if (data.value.hasOwnProperty(k)) {
|
|
|
+ fieldsSchema[k] = rule.defaultField;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ fieldsSchema = _extends({}, fieldsSchema, {}, data.rule.fields);
|
|
|
+
|
|
|
+ for (var f in fieldsSchema) {
|
|
|
+ if (fieldsSchema.hasOwnProperty(f)) {
|
|
|
+ var fieldSchema = Array.isArray(fieldsSchema[f]) ? fieldsSchema[f] : [fieldsSchema[f]];
|
|
|
+ fieldsSchema[f] = fieldSchema.map(addFullfield.bind(null, f));
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ var schema = new Schema(fieldsSchema);
|
|
|
+ schema.messages(options.messages);
|
|
|
+
|
|
|
+ if (data.rule.options) {
|
|
|
+ data.rule.options.messages = options.messages;
|
|
|
+ data.rule.options.error = options.error;
|
|
|
+ }
|
|
|
+
|
|
|
+ schema.validate(data.value, data.rule.options || options, function(errs) {
|
|
|
+ var finalErrors = [];
|
|
|
+
|
|
|
+ if (errors && errors.length) {
|
|
|
+ finalErrors.push.apply(finalErrors, errors);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (errs && errs.length) {
|
|
|
+ finalErrors.push.apply(finalErrors, errs);
|
|
|
+ }
|
|
|
+
|
|
|
+ doIt(finalErrors.length ? finalErrors : null);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ var res;
|
|
|
+
|
|
|
+ if (rule.asyncValidator) {
|
|
|
+ res = rule.asyncValidator(rule, data.value, cb, data.source, options);
|
|
|
+ } else if (rule.validator) {
|
|
|
+ res = rule.validator(rule, data.value, cb, data.source, options);
|
|
|
+
|
|
|
+ if (res === true) {
|
|
|
+ cb();
|
|
|
+ } else if (res === false) {
|
|
|
+ cb(rule.message || rule.field + " fails");
|
|
|
+ } else if (res instanceof Array) {
|
|
|
+ cb(res);
|
|
|
+ } else if (res instanceof Error) {
|
|
|
+ cb(res.message);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if (res && res.then) {
|
|
|
+ res.then(function() {
|
|
|
+ return cb();
|
|
|
+ }, function(e) {
|
|
|
+ return cb(e);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }, function(results) {
|
|
|
+ complete(results);
|
|
|
+ });
|
|
|
+ },
|
|
|
+ getType: function getType(rule) {
|
|
|
+ if (rule.type === undefined && rule.pattern instanceof RegExp) {
|
|
|
+ rule.type = 'pattern';
|
|
|
+ }
|
|
|
+
|
|
|
+ if (typeof rule.validator !== 'function' && rule.type && !validators.hasOwnProperty(rule.type)) {
|
|
|
+ throw new Error(format('Unknown rule type %s', rule.type));
|
|
|
+ }
|
|
|
+
|
|
|
+ return rule.type || 'string';
|
|
|
+ },
|
|
|
+ getValidationMethod: function getValidationMethod(rule) {
|
|
|
+ if (typeof rule.validator === 'function') {
|
|
|
+ return rule.validator;
|
|
|
+ }
|
|
|
+
|
|
|
+ var keys = Object.keys(rule);
|
|
|
+ var messageIndex = keys.indexOf('message');
|
|
|
+
|
|
|
+ if (messageIndex !== -1) {
|
|
|
+ keys.splice(messageIndex, 1);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (keys.length === 1 && keys[0] === 'required') {
|
|
|
+ return validators.required;
|
|
|
+ }
|
|
|
+
|
|
|
+ return validators[this.getType(rule)] || false;
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+Schema.register = function register(type, validator) {
|
|
|
+ if (typeof validator !== 'function') {
|
|
|
+ throw new Error('Cannot register a validator by type, validator is not a function');
|
|
|
+ }
|
|
|
+
|
|
|
+ validators[type] = validator;
|
|
|
+};
|
|
|
+
|
|
|
+Schema.warning = warning;
|
|
|
+Schema.messages = messages;
|
|
|
+
|
|
|
+export default Schema;
|
|
|
+//# sourceMappingURL=index.js.map
|