Skip to content
On this page

API

Contents

ParamValidator

  • ParamValidator.constructor(dataModel: Object, mode: String, forceGlobalDeepClone: Boolean)

    • dataModel: provide the Data Model Object
    • mode: 'strict' | 'sloppy'
    • forceGlobalDeepClone:
      • default: 'false'
      • If true, it will force validator clone every property before validate the data you provide.

      Normally, validator will not clone the Custom Class or the class that is provided by Javascript Engine, such as Date, Promise... Because of the concern about performance, and we think is dangerous and is not necessary. Because the property of custom class and the js engine's class are usually managed by the constructor of a class. So as normal, we will not clone this kind of object, and we promise we will not alter the content in this kind of object. Unless you use sloppy mode or set enableClimb as true.

js
const strictValidator = new ParamValidator({
    obj: Object
}, "strict")

const sloppyValidator = new ParamValidator({
    obj: Object
}, "sloppy")
class Person {}
const person = new Person()
strictValidator.test({obj: person}) //false
sloppyValidator.test({obj: person}) //true
  • ParamValidator.typeof(val)

    • Params:
      • val: value that you want to check
    • Return:
      • String:
        • 'String'
        • 'Number'
        • 'Boolean'
        • 'Object'
        • 'Array'
        • 'undefined'
        • 'null'
        • className
Provide a method to identity the type of value,you can use it identity the type above.
You also can use it to check an instance's constructor
js
console.log(ParamValidator.typeof(1))// 'Number'
console.log(ParamValidator.typeof('match'))// 'String'
console.log(ParamValidator.typeof([]))// 'Array'

class Person {
    
}
const person = new Person()
console.log(ParamValidator.typeof(person))// 'Person'
  • ParamValidator.isType(val,type)

    • Params:
      • val: value that you want to check
      • type: the type you want to check,you can provide constructor or String here
        • String
        • Number
        • Boolean
        • Object
        • Array
        • undefined
        • null
    • Return:
      • Boolean
Provide a method to check if a value can match the type you give

WARN

null and Object is not matched in this method,although they have some connection between them

js
console.log(ParamValidator.isType(1,Number))// true
console.log(ParamValidator.isType('1',Number))// false

class Person {

}
const person = new Person()
console.log(ParamValidator.isType(person,Person))// true

Data Model

Q: What is Data Model?

Data Model is the format of a kind of data. Validator uses Data Model to validate the params in data.

Or you can say Data Model is the description of a kind of data.

For example: {name:"Match",age:20} is an data,and his Data Model can be

"An Object contains 'name' and 'age' these two params, and 'name' needed as String,'age' needed as Number "

You can follow this doc to create a Data Model for validator

  • simple model

    • After the version of 1.2.0
      • You can specify a simple type or built-in model below for a field:
        • Number
        • String
        • Boolean
        • Object
        • Array
        • Function
        • Class
        • undefined
        • null
        • Built-in Model(after Version 1.4.0) More details in Built-in Model
    • You can construct a data model with a simple way like:
js
const { Email, Phone } = ParamValidator
const userModel_1 = {
    name: String,
    age: Number,
    email: Email,
    phone: Phone
}

// You can also use an Array, this means the param can be a Number or a String
// WARN: you can not use built-in model like "Email, Phone..." in Array in now version, but it will be published in the future version
const userModel_2 = {
    name: String,
    age: [Number, String]
}
This way to construct a data model is very simple and quick.

If you don't need to specify other specific option, you are suggested to use this way.

You can mix the simple way and the complex way when you construct a data model, it is allowed and welcomed

js
const personModel = {
    name: String,
    age: {
        type: [Number, String],
        int: true
    }
}
  • basic

    • type: Type | Type-Array
      • To specify the type of param
        • Number
        • String
        • Boolean
        • Object
        • Array
        • Class
        • undefined
        • null
    • required: Boolean
      • To specify if the param is required
      • default: true

      TIP

      1. required only make sure if the data have the specific field. It means the data like {name: undefined} will not to be rejected and the data like { } will be rejected. However, if your type don't include undefined, the former will finally rejected by the type checking.

      2. When the value of required is false, the value of undefined can be accepted and will not cause a wrong validation, such as { name: undefined }.

    • custom: Function (after Version 1.4.0)
      • To give validator a custom function to validate field, the function need a return value that must be Boolean type (true or false). false means that the value fail to pass the validation, true means the opposite.
      • custom function tools: contains some built-in functions that you can use in the custom function
      • More details see Custom Function
    • default: any
      • In this field, you can provide a default value. The field will be filled when the data has no value of this field

ATTENTION

1.default option only works when required is false

2.the priority of the value specified by default is higher than undefined, which means if the validated value is undefined and you define a default value, the default value will cover the value of undefined

js
const dataModel = {
    name: {
        type: String,
        required: true
    },
    age: {
        type: Number,
        required: false
    },
    score: {
        type: [Number,String],// it can be Number or String
        default: 60
    }
}
const validator = new ParamValidator(dataModel)

const data1 = {
    name: 'Match',
    age: 20,
    score: 'A+'
}
const data2 = {
    name: 'Match',
    score: 90
}

console.log( validator.test(data1) ) // true
console.log( validator.test(data2) ) // true
When a param specify more than one type,such as { type: [ Number, Array ] }

You also can use the option below.

  • String

    • range: Array | val
      • The specific value the param can be, you can provide an Array or single value
      • The value in Array is suggested to be Number, String or Boolean
    • regexp: RegExp
      • To specify the RegExp that param need to match
      • default: true
    • empty: Boolean (After Version 1.3.0)
      • To specific the if the String can be an empty String
    • length: Number (After Version 1.3.0)
      • To specific the length of the String, is validate by the property String: length
    • maxLen: Number (After Version 1.3.0)
      • To specific the max length of the String
    • minLen: Number (After Version 1.3.0)
      • To specific the min length of the String
js
const dataModel = {
    name: {
        type: String,
        regexp: /^[A-Z]/
    },
    score: {
        type: String,
        range: ['A+','A','B+','B','C+','C']
    }
}

const validator = new ParamValidator(dataModel)

console.log(validator.test({
    name: 'Match',
    score: 'A+'
}))// true
  • Number

    • range: Array | Object | val
      • The specific value the param can be, you can provide an Array or single value. When type is Number, you can use an Object to describe the range of Number
        • rangeObject: <,>,<=,>=
      • The value in Array is suggested to be Number, String or Boolean
    • int: Boolean
      • To specify the value must be int or not(the int here is not a real int. For example,90.0 is also an int here)
      • default: false
    • isNaN: Boolean (After Version 1.3.0)
      • To specify the value is NaN or not
      • default: false
js
const dataModel = {
    score: {
        type: Number,
        int: true,
        range: {
            "<=": 100,
            ">": 0
        }
    }
}

const validator = new ParamValidator(dataModel)

console.log(validator.test({
    score: 90
}))// true
  • Boolean

    • range: Array | val
      • The specific value the param can be, you can provide an Array or single value.
  • Object

    • items: Object
      • Using this param, you can provide the children of this Object. You can also use Data Model to match these children. param-validator.js make a promise that emitter in validator will do recursion to reach the whole Data Model
    • objItems: Object
      • This property's function is the same as "items".
    • enableClimb: Boolean
      • default: true(sloppy mode) | false(strict mode)
      • If true, validator will climb and find if the prototype property of a constructor appears anywhere in the prototype chain of an object. And the rule is the same as instanceof
In order to distinguish "items" in Object and Array, we add `objItems | arrItems` you can use after the version of 1.1.0

We recommend you to use this property when a data model you set can be Object or Array( type: [Object,Array] )

js
const peopleModel = {
    person: {
        type: Object,
        items: {
            name: {
                type: "String"
            },
            age: {
                type: [String,Number]
            },
            things: {
                type: Object,
                items: {
                    tool: {
                        type: String
                    },
                    lunch: {
                        type: String
                    }
                }
            }
        }
    }
}

const validator = new ParamValidator(peopleModel)

console.log(validator.test({
    person: {
        name: "Match",
        age: 20,
        things: {
            tool: "MacBook",
            lunch: "rice"
        }
    }
}))// true
  • Array

    • items: Object
      • Using this param, you can provide a Data Model to validate the children of this Array.

      Warn: The items here is different with items in Object

    • arrItems: Object (After Version 1.1.0)
      • This property's function is the same as "items".
In order to distinguish "items" in Object and Array, we add `objItems | arrItems` you can use after the version of 1.1.0

We recommend you to use this property when a data model you set can be Object or Array( type: [Object,Array] )

js
const peopleModel = {
    name: {
        type: String
    },
    things: {
        type: Array,
        items: {
            type: Object,
            items: {
                name: {
                    type: String
                },
                brand: {
                    type: String
                }
            }
        }
    }
}

const validator = new ParamValidator(peopleModel)

const person = {
    name:"Match",
    things:[ {name:'MacBook',brand:'Apple'}, {name:'Iphone',brand:'Apple'} ]
}
console.log( validator.test(person) )// true
  • Function

    • name: String
      • To specific function's name
    • length: Number
      • To specific the number of parameters
    • enableAsync: Boolean
      • default: true(sloppy mode) | false(strict mode)
      • if true, async function can pass the validation. Otherwise, it can't.
  • Class

When type is a class, [param-validator.js]() also can accept it and validate if the object is the instance of the class.

But you can not set items to do recursion inside the object. Because it is not necessary and it's dangerous. If you did need that, please use type Object and set property "enableClimb" to true

js
class Person {
    constructor(name,age) {
        this.name = name
        this.age = age
    }
}

const dataModel = {
    person:{
        type:Person
    }
}
const validator = new ParamValidator(dataModel)

const person = new Person('Match', 20)
const data = {
    person
}

console.log( validator.test(data) )// true
  • others

    • type: undefined | null
    • Usage: Sometime we use null to release an Object. It can be used to detect if one of the params become undifined or null.

WARN🔬

It doesn't suggest you to fully dependent on undefined,null as type at now version., Because it is at experiment stage.

validator instance

  • validator.test(Object)

    • Params:
      • Object: the object you want to validate
    • Return:
      • Boolean
Provide a method to validate if the object can match the data model you give
js
const result = validator.test(data)
console.log(result) // true | false
  • validator.construct(oriObject)

    • Params:
      • oriObject: the object you want to validate and construct
    • Return:
      • newObject: a new object that is constructed by validator
    • Error:
      • When the object you provided is not matched the Data Model, it will throw an error when the method is called.
Provide a method to construct and complete the object you provided. But it will not change your origin object.
js
const dataModel = {
    name: {
        type: String,
        regexp: /^[A-Z]/
    },
    age: {
        type: [Number,String],
        required: false,
        int: true,
        range: {
          ">=": 0,
          "<": 200  
        },
        default: 18
    }
}
const validator = new ParamValidator(dataModel)
const oriObj = {
    name: 'Match'
}
const newObj = validator.construct(oriObj)
console.log(newObj)// {name:"Match",age:18}
  • validator.check(Object)

    • Params:
      • Object: the object you want to validate
    • Return:
      • Object (When success)
        • result: true
        • data: Object
      • Object (When error)
        • result: false
        • errorModule: String
        • errorField: String
        • errorType: String
        • msg: String
js
/**
    * Error Type
    *  -required   必须的字段为空
    *  -type       类型错误
    *  -empty      字符串为空错误
    *  -regexp     字符串正则错误
    *  -length     字符串长度错误
    *  -maxLen     字符串长度错误
    *  -minLen     字符串长度错误
    *  -range      值的范围错误
    *  -int        数值整形错误
    *  -isNaN      NaN类型错误 
    *  -model      数据模型错误
    *  -unknown    未知错误
    *  
    * Error Module
    *  -emitter    触发器下的错误
    *  -stringV    字符串校验器的错误
    *  -numberV    数值类型校验器的错误
    *  -objectV    对象校验器的错误
    *  -arrayV     数组校验器的错误
    *  -booleanV   布尔值校验器的错误
    *  -emptyV     空值类型校验器的错误(undefined,null)
    *  -classV     类校验器的错误
    */
Provide a method to validate if the object can match the data model you give and construct a new object just like [construct()](#validatorconstructoriobject).

And return more detail message when validate fail. Through this you can locate the reason more conveniently, and provided more specific error reasons to frontend when you use param-validator.js as validator in http server
js
const dataModel = {
    name:{
        type:String,
        regexp:/^[A-Z]/
    },
    age:{
        type:[Number,String],
        required:false,
        int:true,
        range:{
            ">=":0,
            "<":200
        },
        default:18
    }
}
const validator = new ParamValidator(dataModel)
const oriObj = {
    name: 'Match'
}
const checkReturn = validator.check(oriObj)
console.log(checkReturn)
/**
 * {
 *      result:true,
 *      data:{
 *          name:"Match",
 *          age:18
 *      }      
 * }
 */

Custom Function

Through this way, you can fully customize your validator to create more complicated and more personal validation rules
  • An model property: custom: Function(value, key, config, data) (after Version 1.4.0)
    • To give validator a custom function to validate field, the function need a return value that must be Boolean type (true or false). false means that the value fail to pass the validation, true means the opposite.
    • custom function tools: contains some built-in functions that you can use in the custom function

Usage

  • In this option when you define a data model, you should give a function that must contain a return value which is type of Boolean.
  • When your custom function return true, it means this value can pass the validation. When it returns false, it means you reject this value.
  • param:
    • value: the value of the field
    • key: the key of the value, you figure out which field you are validating
    • config: you can get the completed config of the data model
    • data: you can get the whole data that you are validating
  • custom function tools: you can use this to get an object containing some method you can use to make some change on the value of the data or something else, it will be more and more method constantly added in.
    • alter(newValue: Any)
      • you can use this method to change the value that you are validating
    • alterConfig(field: String, value: Any)
      • you can use this method to change any option in the model config that you are validating
    • ignore()
      • if you call this function in custom function, all the validation procedure will be ignored including the validation of type. And that means you don't need to specific any option except the custom function in data model if you decide to use this method. All the work need to be done by your custom function.
    • ParamValidator
      • you can access all the method provided by ParamValidator
js
const peopleModel = {
    name:{
        type: String,
        custom: function(name) {
            const newName = name.toUpperCase()
            this.alter(newName)
            if (newName === 'MATCH') {
                this.alterData('age', 20)
            }
            return true;
        }
    },
    age:{
        type: Number,
        // if number is not an even then it can't pass the validation
        custom(age) {
            if (age % 2 !== 0) return false
            return true
        }
    }
}

const validator = new ParamValidator(peopleModel)

const person = {
    name:'Match',
    age:18
}
console.log( validator.check(person) )// true

Built-in Model

Q: What is Built-in Model?

ParamValidator provided some Built-in Models, it can help you create data model faster and more conveniently. Built-in Model is essentially a config of data model, which is defined by the ParamValidator author. And the number of Built-in Model will be expended more and more in the future.

After Version 1.4.0

Example of usage:

js
const ParamValidator = require('param-validator.js')
const {UserName, Password, Email, Phone, Integer} = ParamValidator
const userModel = {
    username: UserName,
    password: Password,
    email: Email,
    phone: Phone,
    age: Integer
}
const userValidator = new ParamValidator(userModel)
const user1 = {
    username: 'Match_OvO',
    password: 'Match_12345',
    email: '1033085048@qq.com',
    phone: '12345678901',
    age: 20
}
console.log(userValidator.test(user1)) //true
  • BuiltInModel.prototype.extend(ModelConfig:Object)
    • ModelConfig: Object If you want to customize the built-in models, for example, you want to set a field as Email, but this field is not necessary needed. You can use method: extend(), to provide your own config. This method returns a new Built-in Model and your config will cover the pre-existed config.
js
const {Email, Integer}  = require('param-validator.js')
const validator = new ParamValidator({
    email: Email.extend({required: false}),
    age: Integer.extend({int: false})
})
console.log(validator.test({
    age: 18.2
})) // true

List of Built-in Models:

  • Email: String
  • Url: String
  • IP: String
  • ChineseWord: String
  • Base64: String
  • Phone: String
  • Html: String
  • IntString: String
  • FloatString: String
  • UserName: String
  • Password: String
  • Integer: Number
  • Float: Number
  • Odd: Number
  • Even: Number
  • AsyncFunction: Function

RegexpLibrary

Usage:

js
const {regexpLibrary} = require('param-validator.js')
{
    email: /^\w{3,}(\.\w+)*@[A-z0-9]+(\.[A-z]{2,5}){1,2}$/,
    url: /[a-zA-z]+:\/\/[^\s]*/,
    IP: /((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)/,
    ChineseWord: /[\u4e00-\u9fa5]/,
    base64: /[\/]?([\da-zA-Z]+[\/+]+)*[\da-zA-Z]+([+=]{1,2}|[\/])?/,
    phone: /^\d{11}$/,
    html: /^<([a-z]+)([^<]+)*(?:>(.*)<\/\1>|\s+\/>)$/,
    intString: /^[0-9]+$/,
    floatString: /^[0-9]+\.[0-9]+$/,
    userName: /^[a-zA-Z0-9_]{4,16}$/,
    password: /^(?=.*[a-zA-Z])(?=.*[0-9])(?=.*[!@#$%^&*()_+]).{8,}$/
}

Validation Mode

You can provide a validation mode when you are defining a new validator. With different validation mode, validator will perform different behaviour.

  • option value: "strict" | "sloppy"
  • default value: "strict"
js
const strictValidator = new ParamValidator({}, 'strict')
const sloppyValidator = new ParamValidator({}, 'sloppy')

Strict Mode

input value: "strict"

Strict Mode is the default validation mode, it has a more strict rule for validation. You can simply understand as a behaviour that is more like traditional object-oriented language, such as Java, C++. In Javascript, all the objects are base on a root class(Object). And Javascript's realization of many behaviours in traditional object-oriented language is designed as prototype chain.

In "strict" mode, ParamValidator was designed to cut the prototype chain for more precise type-judgement. For example, if there is a "class Person{}". Although its instance: person is an object, validator will not match it for an Object.

js
class Person{}

const validatorObject = new ParamValidator({
    someone: Object
})
const validatorPerson = new ParamValidator({
    someone: Person
})

const person = new Person()
validatorObject.test({someone: person}) // expected return: false
validatorPerson.test({someone: person}) // expected return: true

Moreover, if a "class Student extends Person{}" is subclass of Person, it will not be matched for Person either.

js
class Person{}
class Student extends Person{}

const validatorPerson = new ParamValidator({
    someone: Person
})
const validatorStudent = new ParamValidator({
    someone: Student
})

const stu = new Student()
validatorPerson.test({someone: stu}) // expected return: false
validatorStudent.test({someone: stu}) // expected return: true

In validation of Number, as normal NaN is treated as a Number, but in "strict" mode, NaN will not be matched as Number.

js
const strictValidator = new ParamValidator({
    num: Number
})
const sloppyValidator = new ParamValidator({
    num: Number
}, "sloppy")

strictValidator.test({num: NaN}) // expected return: false
sloppyValidator.test({num: NaN}) // expected return: true

In validation of Function, AsyncFunction will not be matched as Function

js
const { AsyncFunction } = requrie('param-validator.js')
const strictValidator = new ParamValidator({
    fun: Function
})
const sloppyValidator = new ParamValidator({
    fun: AsyncFunction
}, "sloppy")

strictValidator.test({fun: ()=>{}}) // expected return: false
sloppyValidator.test({fun: async function() {}}) // expected return: true

Sloppy Mode

input value: "sloppy"

Sloppy mode has a more flexible regulation for validation. Such as the children Class/Function will be matched by its father; NaN is treated as a Number. But Array, null, undefined are still be matched separately.

js
const { AsyncFunction } = require('param-validator.js')
class Person{}
class Student extends Person{}

const validatorPerson = new ParamValidator({
    someone: Person,
    num: Number,
    fun: Function,
    obj: Object
})

const stu = new Student()
validatorStudent.test({
    someone: stu,
    num: NaN,
    fun: AsyncFunction,
    obj: stu
}) // expected return: true

That means you can validate the params in a custom class or js-engine's object, which we don't suggest you to do that. But if you do need to, you can set type as Object and use sloppy mode or set enableClimb as true.

TIP

In sloppy mode, validator will automatically use global deep clone algorithm, which has a high performance cost. Because js-engine's object is complicated and contains a lot of native code or property, clone algorithm is hard to ensure to do a perfect clone with the different Javascript engine's feature in the future. And validation procedure may change the property in object when you set some config, such as default value, we can not ensure it will not affect the origin function of the object. If you do need that, we suggest you use some library like lodash to do preprocessing before validation.