Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

async-validate

Package Overview
Dependencies
Maintainers
1
Versions
97
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

async-validate

Asynchronous validation for node and the browser

  • 0.9.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
241
decreased by-37.4%
Maintainers
1
Weekly downloads
 
Created
Source

Table of Contents

Async Validate

Asynchronous validation for node and the browser.

Install

npm i async-validate

Usage

Define validation rules, assign them to a schema using the necessary plugins and call validate:

var Schema = require('async-validate')
  , descriptor = {name: {type: "string", required: true}}
  , schema = new Schema(descriptor)
  , source = {};

Schema.plugin([
  require('../plugin/object'),
  require('../plugin/string'),
  require('../plugin/util')
]);

schema.validate(source, function(err, res) {
  if(err) {
    throw err; 
  }else if(res) {
    // validation failed, res.errors is an array of all errors
    // res.fields is a map keyed by field name with an array of
    // errors per field
    return console.dir(res.errors)
  }
  // validation passed
});

Guide

Descriptor

A descriptor is a collection of validation rules as a map of fields to rules, rules may be declared as an object, array or function.

Object Definition
var descriptor = {
  name: {type: 'string', required: true}
}
Array Definition

You may declare an array to use multiple validation rules per field, see multiple rules.

Function Definition

Use an inline function definition for application specific rules, see inline rule.

Rules

function rule(cb)

Rules are functions that perform validation of a value, they are invoked in the scope of a rule instance (file, api docs).

A rule function can access all relevant properties and methods using this and should raise an error if this.value fails a validation test, see errors. Rule functions may raise multiple errors for different validation failures.

The plugin rule method of declaring rule functions is preferred as it is the most modular.

Inline Rule

The rule function is assigned directly to the field:

var descriptor = {
  id: function(cb) {
    // if this.value has error condition call this.raise() 
    cb();
  }
}
Assigned Rule

Assigned to the validator field so that you may pass data from the rule to the function:

var descriptor = {
  id: {
    foo: 'bar',
    test: function(cb) {
      console.log(this.foo);
      // if this.value has error condition call this.raise() 
      cb();
    }
  }
}
Plugin Rule

Plugin that assigns the rule function as a static method.

Create a plugin module:

module.exports = function() {
  // declare static rule function with name `id`
  this.main.id = function id(cb) {
    // if this.value has error condition call this.raise() 
    cb();
  }
}

Load and use the plugin:

var Schema = require('async-validate');
Schema.plugin([require('./rule')]);
var descriptor = {
  id: {type: 'id'}
}

The static id method will then be invoked for every rule of type id, this is the most portable style as it enables easily moving validation rules into modules and packages that may be shared.

Multiple Rules

It is often useful to test against multiple validation rules for a single field, to do so make the rule an array of objects, for example:

var descriptor = {
  email: [
    {type: "string", required: true},
    function(cb) {
      // test if email address (this.value) already exists 
      // in a database and call this.raise() if it does
      cb();
    }
  ]
}
Deep Rules

If you need to validate deep object properties you may do so for validation rules that are of the object or array type by assigning nested rules to a fields property of the rule.

var descriptor = {
  name: {type: "string", required: true},
  address: {
    type: "object",
    required: true,
    fields: {
      street: {type: "string", required: true},
      city: {type: "string", required: true},
      zip: {type: "string", required: true, len: 8, message: "invalid zip"}
    }
  }
}
var validator = new schema(descriptor);
validator.validate({address: {}}, function(err, res) {
  // res.errors contains errors for name, street, city, zip
});

Note that if you do not specify the required property on the parent rule it is perfectly valid for the field not to be declared on the source object and the deep validation rules will not be executed as there is nothing to validate against.

The parent rule is also validated so if you have a set of rules such as:

var descriptor = {
  roles: {
    type: "array",
    required: true,
    len: 3,
    fields: {
      0: {type: "string", required: true},
      1: {type: "string", required: true},
      2: {type: "string", required: true}
    }
  }
}

And supply a source object of {roles: ["admin", "user"]} then two errors will be created. One for the array length mismatch and one for the missing required array entry at index 2.

Properties

This section describes the recognised rule properties and their behaviour, if you are using an assigned rule or plugin rule you can define properties on the rule object and they are available to the rule function via this.

Type Identifier

The type property indicates the type of rule to use, a type corresponds to a plugin function and the plugin should have been loaded.

Recognised type values are:

  • string: Must be of type string.
  • number: Must be of type number.
  • boolean: Must be of type boolean.
  • method: Must be of type function.
  • null: Must strictly equal null.
  • regexp: Must be an instance of RegExp or a valid string regexp.
  • integer: Must be of type number and an integer.
  • float: Must be of type number and a floating point number.
  • array: Must be an array as determined by Array.isArray.
  • object: Must be of type object and not Array.isArray.
  • enum: Value must exist in the list.
  • date: Value must be valid as determined by moment().isValid().

When the object plugin has been loaded the type field may be a function in which case the value must be an instanceof the function assigned to type.

Test

The test function to use for rule validation.

Additional

When a rule is of the object type and additional is set to false an error is raised if the source object contains any properties not in the schema.

Fields

Rules of the object and array type may declare a fields object which declares a nested schema, see deep rules.

Message

The message rule property defines the error message when validation fails, it overrides any default message. The property may be a string or function, see messages.

Required

The required rule property indicates that the field must exist on the source object being validated.

Pattern

The pattern rule property is a regular expression that the value must match to pass validation.

Range

A range is defined using the min and max properties. For string, function and array types comparison is performed against the length, for number types the number must not be less than min nor greater than max.

Length

To validate an exact length of a field specify the len property. For string, function and array types comparison is performed on the length property, for the number type this property indicates an exact match for the number, ie, it may only be strictly equal to len.

If the len property is combined with the min and max range properties, len takes precedence.

Values

Used with the array type as a shorthand for validating array values, may be an object or array containing validation rules.

When values is an object it is applied to all array elements in the source array otherwise each values entry is compared against each source array entry which allows mixed types to be used in arrays.

Note that values is expanded to fields, see deep rules.

Enumerable

To validate a value from a list of possible values use the enum type with a list property containing the valid values for the field, for example:

var descriptor = {
  role: {type: "enum", list: ['admin', 'user', 'guest']}
}
Date Format

Validating dates can be complex but using moment date validation is substantially easier.

If no format is specified for a rule that is a date type then it is assumed the date is ISO 8601. If a format is specified then the date is validated according to the specified format.

It is recommended you read the moment documentation on the isValid method to understand what validation is performed.

The important part is:

Note: It is not intended to be used to validate that the input string matches the format string. Because the strictness of format matching can vary depending on the application and business requirements, this sort of validation is not included in Moment.js.

This limitation may be overcome by combining a pattern in a date rule, for example:

var descriptor = {
  active: {
    type: "date",
    format: "YYYY-MM-DD",
    pattern: /^([\d]{4})-([\d]{2})-([\d]{2})$/
  }
}
Whitespace

It is typical to treat required fields that only contain whitespace as errors. To add an additional test for a string that consists solely of whitespace add a whitespace property to a rule with a value of true. The rule must be a string type.

You may wish to sanitize user input instead of testing for whitespace, see transform for an example that would allow you to strip whitespace.

Errors

To raise an error in a validation rule call raise, the signature for raise is equivalent to util.format except that it may also accept a Reason as the first argument.

function id(cb) {
  if(!/^[a-z0-9-]+$/i.test(this.value)) {
    this.raise('%s is not a valid id', this.field); 
  }
  cb();
}

Decorate the error with a reason:

function id(cb) {
  if(!/^[a-z0-9-]+$/i.test(this.value)) {
    this.raise(
      this.reason(
        'id', {description: 'Field value failed pattern match'}),
      '%s is not a valid id',
      this.field); 
  }
  cb();
}

Adding a reason allows associating an identifier with an error and optional meta data about the error.

To signal that an internal processing error has occured pass an Error to the callback, for example:

function id(cb) {
  this.model.findById(this.value, function(err, id) {
    if(err) {
      return cb(err); 
    }
    // validate id for error conditions
    cb();
  });
}

Plugins

Plugins are modules defining functions that allow users to only load functionality specific to the rule types being used which allows builds for the browser to be as lean as possible.

See zephyr for plugin system documentation.

Loading Plugins

To load all plugins:

require('async-validate/plugin/all');

It is preferable to only use plugins for the types you are using:

var Schema = require('async-validate');
Schema.plugin([
  require('async-validate/plugin/util'),
  require('async-validate/plugin/array'),
  require('async-validate/plugin/boolean'),
  require('async-validate/plugin/number'),
  require('async-validate/plugin/string')
])
Creating Plugins

Static plugins are mapped to type identifiers and instance plugins may be used to extend Rule which is useful for sharing functionality across rule plugins, see the util plugins.

See plugin rule for an example and plugin contains the plugins that ship with this package.

The important point to remember is that for helper methods assign to this and for static rule functions (located by type) assign to this.main in the plugin.

Helper method:

module.exports = function() {
  // create a helper method on the prototype
  // of the class used for static function scope
  this.helper = function(value) {
    return value;
  }
}

Static method:

module.exports = function() {
  this.main.id = function id(cb) {
    // use helper method
    var val = this.helper(this.value);
    // implement validation for `id` type
    cb();
  }
}
Helper Plugins

The following helper plugins ship with this package, you can use them all with:

Schema.plugin([require('async-validate/plugin/util')]);
required
function required()

Validate a required field, typically invoked from a rule function, raises an error if a required field is not present.

pattern
function pattern()

Validate using a regexp pattern, typically invoked from a rule function, raises an error if a value fails to match a rule regexp pattern.

range
function range()

Validates that a value falls within a given range or is of a specific length, typically invoked from a rule function, raises an error if a value is out of bounds.

Validation

This section describes using the processing options available when calling validate.

Bail

To callback early on the first value that generates a validation error and only report a single error use the bail option. This is useful when a user interface only needs to show the first error condition or if continuing processing would add unnecessary overhead.

Remember that a rule can generate multiple validation errors so if you need more fine grained control you can use the single and first options.

Variables

Sometimes it is useful to pass existing data into all rule functions as transient data so that your rule functions may reference existing code for performing async operations. A common use case would be using a model class to query a database and then validate on the returned data.

To do this you may use the vars processing option when calling validate.

The value should be an Object; each property of the vars object is passed into the Rule scope so that they are available via this.

Be aware that if you use a built in field (see Rule) it will be overwritten.

See the vars test and model fixture for an example.

Messages

Depending upon your application requirements, you may need i18n support or you may prefer different validation error messages.

The easiest way to achieve this is to assign a message to a rule:

{name:{type: "string", required: true, message: "Name is required"}}

You may also use a function for the rule message, it is invoked in the scope of the validator and passed the original message and replacement parameters:

var descriptor = {
  name: {
    type: "string",
    required: true,
    message: function(message, parameters) {
      return this.field + ' is required';
    }
  }
}

If you just want to change the default messages:

var Schema = require('async-validate')
  , messages = require('async-validate/messages')
  , descriptor = {name:{type: "string", required: true}}
  , schema;
messages.required = "%s is a required field";
schema = new Schema(descriptor, {messages: messages});

Potentially you may require the same schema validation rules for different languages, in which case duplicating the schema rules for each language does not make sense.

In this scenario you could just require your own messages file for the language and assign it to the schema:

var Schema = require('async-validate')
  , messages = require('messages-es')
  , descriptor = {name:{type: "string", required: true}}
  , schema = new Schema(descriptor, {messages: messages});

If you are defining your own rule functions it is better practice to assign the message strings to a messages object and then access the messages via the this.messages property within the function.

Transform

Sometimes it is necessary to transform a value before validation, possibly to coerce the value or to sanitize it in some way. To do this add a transform function to the validation rule. The property is transformed prior to validation and re-assigned to the source object to mutate the value of the property in place.

Without the transform function validation would fail due to the pattern not matching as the input contains leading and trailing whitespace, but by adding the transform function validation passes and the field value is sanitized at the same time.

var Schema = require('..')
  , descriptor = {
    name: {
      type: "string",
      required: true, pattern: /^[a-z]+$/,
      transform: function(value) {
        return value.trim();
      }
    }
  }
  , schema = new Schema(descriptor)
  , source = {name: " user  "};

Schema.plugin([
  require('../plugin/object'),
  require('../plugin/string'),
  require('../plugin/util')
]);

schema.validate(source, function(err, res) {
  console.dir(source.name);
});

API

Schema
function Schema(descriptor, [opts])

Encapsulates the rules associated with a descriptor and the logic for performing validation.

messages
function messages([messages])

Get or set the messages associated with the schema.

validate
function validate(source, [options], cb)

Validates a source object against the schema rules.

  • source: The object to validate.
  • options: An object describing processing options for the validation.
  • cb: Callback function to invoke when validation completes.

Options:

  • first: Invoke callback when the first validation rule generates an error.
  • single: Only ever return a single error.
  • bail: Shorthand for single and first.
  • parallel: A boolean indicating that the validation should be executed in parallel.
  • field: Field name for the source object, default is source when not specified.
  • vars: Object map of variables to assign to each rule.
Schema.plugin
function plugin(plugins)

Static plugin loader method; accepts an array of plugin functions.

Schema.clone
function clone(source, [target])

Static clone; deep copies simple objects and arrays, RegExp instances are passed by reference.

Reason
function Reason(id, [opts])

Represents the reason for a validation error, may be created using reason().

You must supply a reason id; if opts are passed they are assigned as properties of the reason instance. When toString() is called on a Reason instance the id is returned.

Rule
function Rule(opts)

Encapsulates the data associated with a validation rule and the value to be validated. Rule functions are invoked in the scope of a Rule instance which exposes the following public fields:

  • rule: The validation rule in the schema descriptor.
  • value: The value of the source object property being validated.
  • field: The name of the field being validated.
  • source: The source object passed to validate().
  • messages: Reference to the schema messages.
  • errors: Array of errors for the field validation.
  • reasons: Map of default error reasons.
isRoot
function isRoot()

Determine if this validation is being performed against the root source object.

reason
function reason(id, [opts])

Create a reason for a validation error, returns a Reason instance suitable for passing as the first argument to raise.

raise
function raise([reason], message, ...)

Adds an error message to the list of errors encountered during validation of a value.

The first argument may optionally be a Reason instance returned by reason() allowing a user to associate an identifier with the validation error and optional additional information. A validation error generated with a Reason has a reason field referencing the supplied reason.

When replacement parameters are supplied the behaviour is identical to util.format.

format
function format(message, ...)

Format a message with replacement parameters like util.format.

Useful when a rule declares message as a function and wishes to construct the error message with parameters.

validates
function validates()

Returns a boolean derived from the rule required property and other factors to determine if the value should be subject to validation.

diff
function diff(expected, received)

Compare two arrays, return false if they are equal otherwise return an array that is the difference between the supplied arrays.

Examples

additional
// generate errors when additional fields are present
var Schema = require('async-validate')
  , opts = {field: 'root'}
  , descriptor = {
      type: 'object',
      additional: false,
      fields: {
        address: {
          type: 'object',
          required: true,
          additional: false,
          fields: {
            street: {type: 'string', required: true},
            city: {type: 'string', required: true},
            zip: {type: 'string', required: true, len: 8, message: 'Invalid zip'}
          }
        }
      }
    }
  , source = {
      id: 'unknown-field',
      name: 'unknown-field',
      address: {
        name: 'unknown-field',
        street: 'Mock St',
        city: 'Mock City',
        zip: '12345678',
      }
    }
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, opts, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: extraneous fields (id, name) found in root] field: 'root', reason: { id: 'additional' } },
  { [Error: extraneous fields (name) found in address] field: 'address', reason: { id: 'additional' } } ]
assigned-rule
// assign a function to a rule
var Schema = require('async-validate')
  , descriptor = {
      id: {
        expected: 'foo',
        test: function(cb) {
          if(this.value !== this.expected) {
            this.raise(
              this.reason('unexpected-id'),
              'id expects %s, got %s',
              this.expected,
              this.value
            ) 
          }
          cb();
        }
      }
    }
  , source = {id: 'qux'}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: id expects foo, got qux] field: 'id', reason: { id: 'unexpected-id' } } ]
bail
// bail on first error encountered
var Schema = require('async-validate')
  , opts = {bail: true}
  , descriptor = {
      address: {
        type: 'object',
        fields: {
          name: {type: 'string', required: true},
          street: {type: 'string', required: true},
          city: {type: 'string', required: true},
          zip: {type: 'string', required: true}
        }
      }
    }
  , source = {address: {name: '1024c'}}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, opts, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: street is required] field: 'street', reason: { id: 'required' } } ]
deep
// validate properties of a nested object
var Schema = require('async-validate')
  , descriptor = {
      address: {
        type: 'object',
        fields: {
          name: {type: 'string', required: true},
          street: {type: 'string', required: true},
          city: {type: 'string', required: true},
          zip: {type: 'string', required: true}
        }
      }
    }
  , source = {address: {name: '1024c', street: 'Mock St', city: 'Mock City'}}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: zip is required] field: 'zip', reason: { id: 'required' } } ]
inline-rule
// assign a function as a rule
var Schema = require('async-validate')
  , reserved = ['foo']
  , descriptor = {
      id: function(cb) {
        if(~reserved.indexOf(this.value)) {
          this.raise('%s is a reserved id', this.value); 
        }
        cb();
      }
    }
  , source = {id: 'foo'}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: foo is a reserved id] field: 'id' } ]
instanceof
// validate a field is an instanceof a function
var Schema = require('async-validate')
  , Component = function Component(){}
  , descriptor = {
      comp: {type: Component, required: true}
    }
  , source = {comp: {}}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: comp is not an instance of Component] field: 'comp', reason: { id: 'instanceof' } } ]
len
// validate a field length
var Schema = require('async-validate')
  , descriptor = {
      func: {type: 'method', required: true, len: 1}
    }
  , source = {func: function noop(){}}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: func must have exactly 1 arguments] field: 'func', reason: { id: 'length' } } ]
max
// validate a field has a maximum length
var Schema = require('async-validate')
  , descriptor = {
      func: {type: 'method', required: true, max: 1}
    }
  , source = {func: function noop(foo, bar){}}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: func cannot have more than 1 arguments] field: 'func', reason: { id: 'max' } } ]
message-function
// override error message with function
var Schema = require('async-validate')
  , descriptor = {
      name: {
        type: 'string',
        required: true,
        message: function(msg, parameters) {
          return this.format(
            'name must be specified (field: %s)', this.field);
        }
      }
    }
  , source = {}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: name must be specified (field: name)] field: 'name', reason: { id: 'required' } } ]
message
// override error message
var Schema = require('async-validate')
  , descriptor = {
      name: {
        type: 'string',
        required: true,
        message: 'name must be specified'
      }
    }
  , source = {}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: name must be specified] field: 'name', reason: { id: 'required' } } ]
min
// validate a field has a minimum length
var Schema = require('async-validate')
  , descriptor = {
      func: {type: 'method', required: true, min: 1}
    }
  , source = {func: function noop(){}}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: func must have at least 1 arguments] field: 'func', reason: { id: 'min' } } ]
multiple
// validate a field with multiple rules
var Schema = require('async-validate')
  , data = {bar: 'qux'}
  , descriptor = {
      id: [
        {type: 'string', required: true},
        function exists(cb) {
          if(!data[this.value]) {
            this.raise(
              this.reason('missing-id'),
              'id %s does not exist', this.value);
          }
          cb();
        }
      ]
    }
  , source = {id: 'foo'}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: id foo does not exist] field: 'id', reason: { id: 'missing-id' } } ]
pattern
// validate a field as matching a pattern
var Schema = require('async-validate')
  , descriptor = {
      name: {type: 'string', required: true, pattern: /^[a-z0-9]+$/i}
    }
  , source = {name: '-name'}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: name value -name does not match pattern /^[a-z0-9]+$/i] field: 'name', reason: { id: 'pattern' } } ]
plugin-rule
// validate a field with a plugin rule
var Schema = require('async-validate')
  , descriptor = {
      id: {type: 'id', required: true}
    }
  , source = {id: '-foo'}
  , schema;

require('async-validate/plugin/all');

// create plugin function
function plugin() {
  var pattern = /^[a-z0-9-]$/i;
  // create static rule function
  this.main.id = function id(cb) {
    if(!pattern.test(this.value)) {
      this.raise(this.reason('id'), 'invalid id %s', this.value);
    }
    cb();
  }
}

// use plugin
Schema.plugin([plugin]);

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: invalid id -foo] field: 'id', reason: { id: 'id' } } ]
range
// validate a field has a length within a range
var Schema = require('async-validate')
  , descriptor = {
      func: {type: 'method', required: true, min: 1, max: 2}
    }
  , source = {func: function noop(foo, bar, qux){}}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: func must have arguments length between 1 and 2] field: 'func', reason: { id: 'max' } } ]
required
// validate a field as required
var Schema = require('async-validate')
  , descriptor = {
      name: {type: 'string', required: true}
    }
  , source = {}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: name is required] field: 'name', reason: { id: 'required' } } ]
source-type
// validate the type of the source object
var Schema = require('async-validate')
  , descriptor = {type: 'object'}
  , source = 'foo'
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: source is not an object] field: 'source', reason: { id: 'type' } } ]
type
// validate a field type
var Schema = require('async-validate')
  , descriptor = {
      flag: {type: 'boolean', required: true}
    }
  , source = {flag: 'foo'}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: flag is not a boolean] field: 'flag', reason: { id: 'type' } } ]
whitespace
// validate a field as whitespace
var Schema = require('async-validate')
  , descriptor = {
      name: {type: 'string', required: true, whitespace: true}
    }
  , source = {name: '  '}
  , schema;

require('async-validate/plugin/all');

schema = new Schema(descriptor);
schema.validate(source, function(err, res) {
  console.dir(res.errors);
});
[ { [Error: name cannot be empty] field: 'name', reason: { id: 'whitespace' } } ]

Developer

Clone the repository, run npm i and install mdp globally.

Test

Run the test specifications:

npm test

Spec

Compile test specifications for the browser (open test/index.html):

npm run spec

Cover

Generate code coverage:

npm run cover

Browserify

Create a standalone browserify build:

npm run browserify

Clean

Remove generated files:

npm run clean

Docs

To generate all documentation:

npm run docs

Readme

Generate the project readme file mdp:

npm run readme

License

Everything is MIT. Read the license if you feel inclined.

Generated by mdp(1).

Keywords

FAQs

Package last updated on 16 Sep 2015

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc