Socket
Socket
Sign inDemoInstall

@ckpack/parameter

Package Overview
Dependencies
0
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @ckpack/parameter

JSON validator for Node.js and browser


Version published
Weekly downloads
12
increased by500%
Maintainers
1
Install size
47.4 kB
Created
Weekly downloads
 

Changelog

Source

2.9.0 (2022-04-01)

Features

  • 添加多语言支持 (5872990)

Readme

Source

Parameter

JSON validator for Node.js and browser by using simple configuration rule

Usage

API

Class

Parameter Class

  • constructor([options]) - New Class Parameter instance
    • options.isUseDefault - If use default value, default to true
    • options.isRemoveAdditional - Delete is not defined in the rule as an attribute, default to false
    • options.isCoerceTypes - Change data type of data to match type keyword, default to false
    • options.emptyValues - The contained value will be treated as a empty value, default to [null, undefined, NaN, '']
  • schema(rule, [options]) - Returns a validate with fixed parameters
  • validate(rule, value, [options]) - Validate the value conforms to rule. return an array of errors if break rule
    • rule - The rule of the verified json
    • value - JSON to be verified
    • options - Override the definition of constructor([options])
  • addRule(type, checkFunction) - Add custom rules.
    • type - Rule type, required and must be string type.
    • checkFunction(rule, value) - Custom check rule function.
import { Parameter } from '@ckpack/parameter';

const parameter = new Parameter();

// check rule
const rule = {
  isAdmin: {
    type: 'boolean',
  },
  age: {
    type: 'int',
    min: 0,
  },
  role: {
    type: 'enum',
    enum: ['am', 'pm'],
  }
  ids: {
    type: 'array',
    itemType: 'int',
    itemRule: {
      min: 1
    }
  }
}

// check value
const data = {
  isAdmin: true,
  age: 18,
  role: 'am',
  ids: [1, 2, 3]
};

const errors = parameter.validate(rule, data);

Function

setLocale 设置错误信息语言

设置默认语言为中文

import { zhLocale, setLocale, Parameter } from '@ckpack/parameter';

setLocale(zhLocale);

const parameter = new Parameter();

// parameter.validate(rule, data);

RULE

common rules
  • type: The rule type
  • message: Custom error message
  • isRequired: If check the empty value, default to true
  • default: Is isUseDefault is true, the empty value will be set default value, default to undefined
int

If type is int, There are the following options rules

  • max - The maximum of the value, value must <= max
  • min - The minimum of the value, value must >= min
{
  score: 'int',
}
// or
{
  score: {
    type: 'int',
    min: 0,
    max: 200,
  }
}
number

If type is number, There are the following options rules

  • max - The maximum of the value, value must <= max
  • min - The minimum of the value, value must >= min

example

{
  score: 'number',
}
// or
{
  score: {
    type: 'number',
    min: 0,
    max: 100,
  }
}
string

If type is string, There are the following options rules

  • regexp - A RegExp to check string's format
  • max - The maximum length of the string
  • min - The minimum length of the string

example

{
  username: 'string',
}
// or
{
  username: /\S{4,20}/,
}
// or
{
  username: {
    type: 'string',
    regexp: /\S{4,20}/
  }
}
boolean

If type is boolean

example

{
  isAll: 'boolean',
}
// or
{
  isAll: {
    type: 'boolean',
  }
}
array

If type is array, There are the following options rules

  • itemType - The type of every item in this array
  • itemRule - The rule of every item in this Rule
  • itemChecker- The checker of every item, in this case you can omit itemType and itemRule
  • max - The maximun length of the array
  • min - The minimum length of the array

example

{
  ids: {
    itemType: 'int',
    itemRule: {
      min: 1,
      max: 1000,
    },
    min: 0,
    max: 100,
  }
}

enum

If type is enum, There are the following rules

  • enum- An array of data, value must be one on them

example

{
  sex: ['man', 'woman']
}
// or
{
  sex: {
    type: 'enum'
    enum: ['man', 'woman']
  }
}

object

If type is object, There are the following rules

  • rule- An object that validate the properties ot the object

example

{
  people: {
    type: 'object',
    rule: {
      name: 'string',
      age: {
        isRequired: false,
        type: 'int',
        min: 1,
        max: 200
      }
    }
  }
}

custom rule

definition custom rule, example

// custom check
parameter.addRule('even', (rule, value) => {
  return value % 2 === 0 ? null : `${value} is not even`;
});

use the custom rule

{
  someNumber: 'even'
}
//or
{
  someNumber: {
    type: "even",
  }
}

you alse can add options rules

import { Parameter } from '@ckpack/parameter';
const parameter = new Parameter();
parameter.addRule('times', (rule, value) => {
  const { times } = rule;
  return value % times === 0 ? null : `not an integer multiple of ${times}`;
});

// rule
{
  someNumber: {
    type: "times",
    times: 3,
  }
}

complex example

Keywords

FAQs

Last updated on 01 Apr 2022

Did you know?

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc