Skip to content

A functional semantic validator tool for validation of several types and rich content.

License

Notifications You must be signed in to change notification settings

chenzitw/semantic-validator

Repository files navigation

Semantic Validator

A functional semantic validator tool for validation of several types and rich content, inspired by prop-types from React.

npm version Build Status Coverage Status

Get started

Using NPM or Yarn

First, install it via npm.

npm i semantic-validator

Then, import it from dependencies and enjoy it.

import { op, is } from 'semantic-validator';

const validate = op.shape({
  id: is.integer(),
  tags: op.every(is.string()),
});

Using script tag

First, add a script tag with to the HTML page.

<script src="https://unpkg.com/semantic-validator/bundle.js" crossorigin></script>

Then, just enjoy it.

var op = semanticValidator.op;
var is = semanticValidator.is;

var validate = op.shape({
  id: is.integer(),
  tags: op.every(is.string())
});

Usage

The base unit of the semantic validator is a function which accepts the value as an argument for validation. We define it in TypeScript like below.

type Validator<T = any> = (val: T) => boolean;

This validator tool has several methods in two types: validator operator (op) and validator creator (is).

For example, we can call a validator creator such as is.integer() to create a validator which expects the number should be an integer. We can also call is.greaterThan(100) to create a validator which expects the number is greater than 100.
If we want to match both conditions, we can use a validator operator like op.and(validator1, validator2) to combine two validators.

import { op, is } from 'semantic-validator';

const isInt = is.integer();
isInt(12); // => true;
isInt(12.34); // => false;

const isGt100 = is.greaterThan(100);
isGt100(150); // => true;
isGt100(50); // => false;

const isIntGt100 = op.and(
  is.integer(),
  is.greaterThan(100),
);
isIntGt100(123); // => true;
isIntGt100(123.456); // => false;
isIntGt100(12); // => false;

You can also integrate other validation tools together. Just follow the validator pattern.

For example, there is a method isUUID(str, version) for validating a string. We can make a validator like val => isUUID(val, 5) and compose with other validator operators.

import { op, is } from 'semantic-validator';

const validate = op.shape({
  id: (val => isUUID(val, 5)),
  name: is.string(),
});
validate({ id: '6fad3a7b-161b-5e10-b265-8d522f3f35b5', name: 'Agent K' }); // => true;
validate({ id: 'abc', name: 'Agent K' }); // => false;

Cheatsheet

Method Description
Basic validator operators
> op.so(validator) Pass the validator.
> op.not(validator) Not pass the validator.
> op.and(...validators) Pass all validators.
> op.or(...validators) Pass any validators.
> op.every(validator) Pass the validator on all elements in an array.
> op.some(validator) Pass the validator on any elements in an array.
> op.shape({ ...validatorOfKeys }) Pass all validators for each properties of an object.
> op.exact({ ...validatorOfKeys }) Pass all validators for each properties of an exact object.
Converter validator operators
> op.convert(converter, validator) Pass the validator after converted.
> op.toFloat(validator) Pass the validator after converted to a float.
> op.toInteger(validator) Pass the validator after converted to an integer.
> op.toLength(validator) Pass the validator after converted to the length.
> op.toSplit(separator, validator) Pass the validator after splitted the string as an array.
> op.toKeys(validator) Pass the validator after converted to keys of an object.
> op.toValues(validator) Pass the validator after converted to values of an object.
> op.toDate(validator) Pass the validator after converted to a date object.
Basic validator creators
> is.same(value) Is the same as the base value?
> is.oneOf(...values) Is the same as any base values?
> is.defined() Is defined (not undefined)?
> is.notDefined() Is undefined?
> is.nul() Is null?
> is.nil() Is undefined or null?
> is.bool() Is a boolean?
> is.number() Is a number?
> is.string() Is a string?
> is.object() Is a non null object?
> is.func() Is a function?
> is.symbol() Is a symbol?
> is.instanceOf(constructor) Is an instance of the constructor (class)?
> is.float() Is a valid (not NaN or Infinity) float?
> is.integer() Is a valid (not NaN or Infinity) integer?
> is.array() Is an array?
> is.date() Is a valid (not Invalid Date) date object?
Math validator creators
> is.equalTo(num) Is the number equal to the base number?
> is.greaterThan(num) Is the number greater than the base number?
> is.atLeast(num) Is the number at least the base number?
> is.lessThan(num) Is the number less than the base number?
> is.atMost(num) Is the number at most the base number?
> is.between(min, max) Is the number between the base numbers?
> is.fromTo(min, max) Is the number from and to the base numbers?
Text validator creators
> is.match(regexp) Is the string match the regular expression?
> is.startsWith(wording) Is the string starts with the wording?
> is.endsWith(wording) Is the string ends with the wording?
> is.contains(wording) Is the string contains the wording?
List validator creators
> is.includes(...includings) Is the array includes all includings?
> is.excludes(...excludings) Is the array excludes all excludings?
> is.restrictedBy(...allowedItems) Is the array only includes allowed items?
> is.distinct() Is items of the array are all different?
Date validator creators
> is.moment(date) Is the date object at the moment of the base date object?
> is.laterThan(date) Is the date object later than the base date object?
> is.atEarliest(date) Is the date object at earliest the base date object?
> is.earlierThan(date) Is the date object earlier than the base date object?
> is.atLatest(date) Is the date object at latest the base date object?

Validator operator reference

Basic

op: so
Will be valid when the validator returns true. It is usually not necessary.

op.so(validator)

Example:

const validate = op.so(is.same('hello'));
validate('hello'); // => true
validate('bye'); // => false

op: not
Will be valid when the validator returns false.

op.not(validator)

Example:

const validate = op.not(is.same('hello'));
validate('bye'); // => true
validate('hello'); // => false

op: and
Will be valid when all validators return true.

op.and(validator1, validator2, ...validators)

Example:

const validate = op.and(is.integer(), is.greaterThan(100));
validate(120); // => true
validate(80); // => false
validate(123.456); // => false

op: or
Will be valid when any validator returns true.

op.or(validator1, validator2, ...validators)

Example:

const validate = op.or(is.nul(), is.integer());
validate(null); // => true
validate(123); // => true
validate('abc'); // => false

op: every
Will be valid when validator returns true on all elements in the array.

op.every(validator)

Example:

const validate = op.every(is.integer());
validate([1, 2, 3]); // => true
validate([1, 2.22, 3]); // => false

op: some
Will be valid when validator returns true on any element in the array.

op.some(validator)

Example:

const validate = op.some(is.integer());
validate([1, 2, 3]); // => true
validate([1.11, 2, 3.33]); // => true
validate([1.11, 2.22, 3.33]); // => false

op: shape
Will be valid when value is an object and all validator returns true on each key.

op.shape({
  [key1]: validator1,
  [key2]: validator2,
  ...keysWithValidator,
})

Example:

const validate = op.shape({
  id: is.integer(),
  name: is.string(),
});
validate({ id: 123, name: 'Mr. Sandman' }); // => true
validate({ id: 123, name: 'Mr. Sandman', active: true }); // => true
validate({ id: 123 }); // => false
validate({ id: 123, name: 456 }); // => false

op: exact
Will be valid when value is an object with specific keys and all validator returns true on each key.

op.exact({
  [key1]: validator1,
  [key2]: validator2,
  ...keysWithValidator,
})

Example:

const validate = op.exact({
  id: is.integer(),
  name: is.string(),
});
validate({ id: 123, name: 'Mr. Sandman' }); // => true
validate({ id: 123, name: 'Mr. Sandman', active: true }); // => false
validate({ id: 123 }); // => false
validate({ id: 123, name: 456 }); // => false

Converter

op: convert
Will be valid when successfully converts the value and the validation is success.

op.convert(converter, validator)

Example:

const validate = op.convert(
  numeric => parseFloat(numeric),
  is.greaterThan(100)
);
validate('150'); // => true
validate('50'); // => false

op: to float
Will be valid when successfully converts to a float and the validation is success.

op.toFloat(validator)

Example:

const validate = op.toFloat(is.greaterThan(1.2));
validate('1.5'); // => true
validate('two'); // => false
validate('0.8'); // => false

op: to integer
Will be valid when successfully converts to an integer and the validation is success.

op.toInteger(validator)

Example:

const validate = op.toInteger(is.greaterThan(100));
validate('150'); // => true
validate('two'); // => false
validate('123.456'); // => false
validate('50'); // => false

op: to length
Will be valid when successfully get the length of an array or string and the validation is success.

op.toLength(validator)

Example:

const validate = op.toLength(is.atLeast(3));
validate(['a', 'b', 'c']); // => true
validate('abc'); // => true
validate(['a', 'b']); // => false
validate('ab'); // => false
validate(3); // => false

op: to split
Will be valid when successfully split to the array and the validation is success.

op.toSplit(separator, validator)

Example:

const validate = op.toSplit(',', op.every(is.startsWith('c')));
validate('candy,cookie,coffee'); // => true
validate('candy,cookie,tea'); // => false
validate(123); // => false

op: to keys
Will be valid when successfully get keys of an object and the validation is success.

op.toKeys(validator)

Example:

const validate = op.toKeys(op.every(is.oneOf('id', 'name')));
validate({ id: 123, name: 'Mario' }); // => true
validate({ id: 123, name: 'Mario', age: 20 }); // => false

op: to values
Will be valid when successfully get values of an object and the validation is success.

op.toValues(validator)

Example:

const validate = op.toValues(op.every(is.integer()));
validate({ people: 64, seats: 80 }); // => true
validate({ people: 640, seats: 'many' }); // => false

Validator creator reference

Basic

is: same
Will be valid when base value and compare value are the same by using the SameValueZero algorithm.

is.same(baseValue)

Example:

const validate = is.same('hello');
validate('hello'); // => true

is: one of
Will be valid when one of base values and compare value are the same by using the SameValueZero algorithm.

is.oneOf(...baseValues)

Example:

const validate = is.oneOf(100, '100', 'one hundred');
validate('100'); // => true

is: defined
Will be valid when the value is defined (not undefined).

is.defined()

Example:

const validate = is.defined();
validate(123); // => true
validate(undefined); // => false

is: not defined
Will be valid when the value is not defined (undefined).

is.notDefined()

Example:

const validate = is.notDefined();
validate(undefined); // => true
validate(123); // => false

is: nul
Will be valid when the value is null.

is.nul()

Example:

const validate = is.nul();
validate(null); // => true
validate(123); // => false

is: nil
Will be valid when the value is undefined or null.

is.nil()

Example:

const validate = is.nil();
validate(undefined); // => true
validate(null); // => true
validate(123); // => false

is: bool
Will be valid when the value is a boolean.

is.bool()

Example:

const validate = is.bool();
validate(false); // => true
validate(123); // => false

is: number
Will be valid when the value is a number.

is.number()

Example:

const validate = is.number();
validate(123); // => true
validate('abc'); // => false

is: string
Will be valid when the value is a string.

is.string()

Example:

const validate = is.string();
validate('abc'); // => true
validate(123); // => false

is: object
Will be valid when the value is a non null object.

is.object()

Example:

const validate = is.object();
validate({ key: 'value' }); // => true
validate({}); // => true
validate(null); // => false
validate(123); // => false

is: func
Will be valid when the value is a function.

is.func()

Example:

const validate = is.func();
validate(() => {}); // => true
validate(123); // => false

is: symbol
Will be valid when the value is a symbol.

is.symbol()

Example:

const validate = is.symbol();
validate(Symbol('abc')); // => true
validate('abc'); // => false

is: instance of
Will be valid when the value is the instance of a constructor.

is.instanceOf(constructor)

Example:

const validate = is.instanceOf(Date);
validate(new Date()); // => true
validate(123); // => false

is: float
Will be valid when the value is a float and not NaN or infinity.

is.float()

Example:

const validate = is.float();
validate(123.456); // => true
validate(123); // => true
validate('123'); // => false

is: integer
Will be valid when the value is a integer and not NaN or infinity.

is.integer()

Example:

const validate = is.integer();
validate(123); // => true
validate(123.456); // => false

is: array
Will be valid when the value is an array object.

is.array()

Example:

const validate = is.array();
validate([1, 2, 3]); // => true

is: date
Will be valid when the value is a valid date object.

is.date()

Example:

const validate = is.date();
validate(new Date()); // => true
validate(new Date('invalid date')); // => false
validate('invalid date'); // => false

Math

is: equal to
Will be valid when the value is equal to the number.

is.equalTo(num)

Example:

const validate = is.equalTo(100);
validate(100); // true
validate(200); // false

is: greater than
Will be valid when the value is greater than the number.

is.greaterThan(num)

Example:

const validate = is.greaterThan(100);
validate(101); // => true
validate(100); // => false

is: at least
Will be valid when the value is at least the number.

is.atLeast(num)

Example:

const validate = is.atLeast(100);
validate(100); // => true
validate(99); // => false

is: less than
Will be valid when the value is less than the number.

is.lessThan(num)

Example:

const validate = is.lessThan(200);
validate(199); // => true
validate(200); // => false

is: at most
Will be valid when the value is at most the number.

is.atMost(num)

Example:

const validate = is.atMost(200);
validate(200); // => true
validate(201); // => false

is: between
Will be valid when the value is between the numbers.

is.between(min, max)

Example:

const validate = is.between(0, 10);
validate(5); // => true
validate(0); // => false
validate(10); // => false

is: from to
Will be valid when the value is from and to the numbers.

is.fromTo(min, max)

Example:

const validate = is.fromTo(1, 9);
validate(1); // => true
validate(9); // => true
validate(0); // => false
validate(10); // => false

Text

is: match
Will be valid when the value matches the regular expression.

is.match(regexp)

Example:

const validate = is.match(/^b[aeiou]t$/);
validate('bat'); // => true
validate('brt'); // => false

is: starts with
Will be valid when the value starts with the wording.

is.startsWith(wording)

Example:

const validate = is.startsWith('net');
validate('network'); // => true
validate('artwork'); // => false

is: ends with
Will be valid when the value ends with the wording.

is.endsWith(wording)

Example:

const validate = is.endsWith('fox');
validate('firefox'); // => true
validate('firewall'); // => false

is: contains
Will be valid when the value contains the wording.

is.contains(wording)

Example:

const validate = is.contains('lie');
validate('believe'); // => true
validate('behave'); // => false

List

is: includes
Will be valid when the array value includes all includings.

is.includes(including1, including2, ...includings)

Example:

const validate = is.includes(10, 20, 30);
validate([0, 10, 20, 30, 40]); // => true
validate([0, 20, 40]); // => false

is: excludes
Will be valid when the array value excludes all excludings.

is.excludes(excluding1, excluding2, ...excludings)

Example:

const validate = is.excludes(5, 15, 25);
validate([0, 10, 20, 30]); // => true
validate([5, 10]); // => false

is: restricted by
Will be valid when the array value is restricted by allowed items.

is.restrictedBy(allowedItem1, allowedItem2, ...allowedItems)

Example:

const validate = is.restrictedBy(5, 10, 15, 20);
validate([10, 20]); // => true
validate([5, 10, 15, 20, 25, 30]); // => false

is: distinct
Will be valid when items of array value are all different.

is.distinct()

Example:

const validate = is.distinct();
validate([1, 2, 3]); // => true
validate([1, 2, 3, 3]]); // => false

About

A functional semantic validator tool for validation of several types and rich content.

Resources

License

Stars

Watchers

Forks

Packages

No packages published