1.0.9 • Published 5 years ago

validate-mini v1.0.9

Weekly downloads
2
License
ISC
Repository
github
Last release
5 years ago

validate-mini

Minimalistic validation library. Designed to be as little verbose as possible.

Usage

Import the module

const { validate } = require("validate-mini");

Define a validation schema

const schema = {
    firstName: /[A-Z][a-z]{2,20}/,
    lastName: /[A-Z][a-z]{2,20}/,
};

Execute the validate() function, supplying your schema and the object to validate.

const validationResult = validate(schema, request.body);

The resulting object contains an isValid Boolean property. It indicates whether a validation error has been found or not, and messages for all properties that failed.

// No validation error
{ isValid: true }

// Validation errors
{
    isValid: false,
    firstName: "Invalid format",
    lastName: "Invalid format"
}

Supported validation rules

Specific String, Number or Boolean

To validate against specific String, Number or Boolean values:

const schema = {
    acceptTerms: true,
    verificationText: "I accept",
    rejectionCount: 0
};

RegExp

To validate against a RegExp:

const schema = {
    age: /^[1-9]{1, 2}$/
};

Function

For added flexibility, functions can be used for custom validation. Functions should either return a Boolean, or an object with an isValid Boolean property.

const moment = require("moment");

const schema = {
    dob: value => moment().diff(moment(value), "years") >= 18
};

Functions take at least one argument as parameter. This parameter represents the value of the corresponding property on the object to validate.

Checking against other properties

Functions can also take a second argument, representing the whole object being validated. This allows checking several properties in one function.

const schema = {
    password: /[A-Z]{8,24}/,
    confirmPassword: (value, input) => value === input.password,
};

Arrays

To apply validation rules on Array items:

const schema = {
    aliases: [
        // use any rule you want: RegExp, func, etc
        /[A-Z][a-z]{2,20}/
    ]
}

Objects

Rules can be combined to form complex objects:

const schema = {
    user: {
        name: /[A-Z][a-z]{2,20}/,
        id: /[a-f0-9]{8}/,
        options: {
            // ...
        }
    }
}

Utils

The library comes with a handful of built-in functions to help defining simple validation schemes.

To access the util functions:

const { validate, is, utils } = require("validate-mini");

const schema = {
    products: is.array,
    accept: is.boolean,
    amount: is.number,
    someObjecT: is.object,
    description: is.string,
    // Validate min and max length of Number value
    freeText: utils.length(0, 255),
    // List of acceptable values (enum like)
    status: utils.oneOf("success", "failure", "pending", "canceled"),
    // Validate min and max of Number value
    amount: utils.range(0, 100),
}

Note: When possible, avoid using utils.is, as it creates new functions on every call. Use the is.xxx functions instead.

Optional properties

By default, all rules require matching input. To mark rules as optional, use the optional(<rule>) function together with any rule you like.

const { validate, optional, utils } = require("validate-mini");

const schema = {
    middleName: optional(utils.is(String))
};

Chain several rules

Apply a sequence of rule using the pipe(<rules>) function:

const { validate, pipe } = require("validate-mini");

const schema = {
    password: pipe(/[A-Za-z]/, /[0-9]/, /.{8,255}/)
};
1.0.9

5 years ago

1.0.7

6 years ago

1.0.6

6 years ago

1.0.5

6 years ago

1.0.4

6 years ago

1.0.3

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago