Skip to content

A runtime data validator in TypeScript with advanced type inference, built-in validation functions, and seamless integration for server and client environments.

Notifications You must be signed in to change notification settings

x-keyscore/VALI.TS

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

VALI.TS · npm version

Runtime data validator witten in TypeScript.

Powerful and Smart Validation – Seamlessly integrates into server and client environments.

🧠 Advanced Type Inference – With advanced type inference, you can retrieve a type that strictly adheres to your schema definition. Combined with Type Guards, this ensures that the validated data’s type is precisely inferred, allowing you to handle your data safely and reliably across your application.

📦 Built-in Validation – Standard functions like isEmail, isUuid, and more to handle common validation needs effortlessly, while ensuring industry-standard compliance, saving you from writing tedious custom validators 🚀.

Table of Contents

Getting started

npm install vali.ts
import { Schema, SchemaInfer } from 'vali.ts';

const userSchema = new Schema({ 
  type: "struct",
  struct: {
    name: { type: "string" },
    role: {
        type: "string",
        enum: ["ADMIN", "WORKER", "CUSTOMER"]
    }
  }
});

type UserSchema = SchemaInfer<typeof userSchema>;

let data: unknown = { name: "Tintin", role: "ADMIN" };

if (userSchema.guard(data, (reject) => console.log(reject))) {
    /*
    The data type is now:
    data: {
        name: string;
        role: "ADMIN" | "WORKER" | "CUSTOMER";
    }
    */
    console.log(data);
}



Schema

Instance

Property / Method Description
criteria Property you need if you wish to use this schema in another one.
guard() Type guard method that returns a boolean.
Learn more about type guards
check() Method that returns SchemaReject if the value is rejected, otherwise null.
guard(value, rejectCallback?: (reject: SchemaReject) => void) => boolean;
check(value) => SchemaReject | null;
interface SchemaReject {
  /** `REJECT_<CATEGORY>_<DETAIL>` */
  code: string;
  type: string;
  path: string;
  label: string | undefined;
  message: string | undefined;
};

Exemple :

Note

The criteria properties of schemas are mounted only once, even if you use them in another schema. This can be useful if memory is an important consideration for you or if you plan to create many sub-schemas.

const nameFormat = new Schema({
  label: "NAME_FORMAT",
  type: "string",
  min: 3,
  max: 32
});

const ageFormat = new Schema({
  label: "AGE_FORMAT",
  type: "number",
  min: 13,
  max: 128
});

const userSchema = new Schema({ 
  type: "struct",
  struct: {
    name: nameFormat.criteria,
    age: ageFormat.criteria
  }
});

let data: unknown = { name: "Waitron", age: 200 };

const reject = userSchema.check(data);

console.log(reject);
{
  code: 'REJECT_VALUE_SUPERIOR_MAX',
  path: 'root.struct.age',
  type: 'number',
  label: 'AGE_FORMAT',
  message: undefined
}

Definition

NumberStringBooleanStructRecordTupleArrayUnionSymbol

Note

The order of property definitions in the arrays is the same as when executing the tests by the checker.

Global

Property Type Default Description
nullable? boolean false Allows null
undefinable? boolean false Allows undefined
label? string String that will be returned in the reject object. Ideal for adding your own error codes, for example.
message? string String that will be returned in the reject object.
const schema = new Schema({
  type: "string",
  optional: true,
  label: "OPTIONAL_STRING"
});

Number

Property
Type
Description
type "number" Type name
min? number Minimum value accepted
max? number Maximum value accepted
enum? number[]|Record<string, number> Restrict the value to the items of an array, the values of an object, or the values of a TypeScript Enum.
custom? (x: number) => boolean Customized test function
const schema = new Schema({
  type: "number",
  min: 0,
  max: 50,
  custom(x) {
    return (x % 2 === 0);
  }
});

String

Property
Type Default
Description
type "string" Type name
empty? boolean true If the string can be empty
min? number Minimum length accepted
max? number Maximum length accepted
enum? string[]|Record<string, string> Restrict the value to the items of an array, the values of an object, or the values of a TypeScript Enum.
regex? RegExp A native regex
tester? { name: string, params: object} Allows you to directly apply a test that you will find here, with its parameters if necessary.
custom? (x: string) => boolean Customized test function
const schema = new Schema({
  type: "string",
  min: 0,
  max: 6,
  empty: false,
  tester: { name: "isAscii" }
});

Boolean

Property Type Default Description
type "boolean" Type name
const schema = new Schema({
  type: "boolean"
});

Struct

Property Type Description
type "struct" Type name
optional? Array<string | symbol> Array of optional keys
struct Record<string | symbol, Criteria> The object's keys represent the expected keys
and the attributes represent the expected types.
By default, the keys are considered required.
const schema = new Schema({
  type: "struct",
  optional: ["description"],
  struct: {
    fistname: { type: "string" },
    lastname: { type: "string" },
    description: { type: "string" }
  }
});

Record

Property Type Default Description
type "record" Type name
empty? boolean false If the object can be empty
min? number Minimum properties accepted
max? number Maximum properties accepted
key Criteria<string | symbol> Criteria of key
value Criteria Criteria of value
const schema = new Schema({
  type: "record",
  max: 10,
  key: { type: "string" },
  value: { type: "number" }
});

Tuple

Property Type Default Description
type "tuple" Type name
tuple [Criteria, ...Criteria[]] Criteria of the tuple items
const schema = new Schema({
  type: "tuple",
  tuple: [{ type: "string" }, { type: "number" }
});

Array

Property Type Default Description
type "array" Type name
empty? boolean false If the array can be empty
min? number Minimum items accepted
max? number Maximum items accepted
item Criteria Criteria of the array items
const schema = new Schema({
  type: "array",
  empty: true,
  tuple: [{ type: "string" }, { type: "number" }
});

Union

Property Type Default Description
type "union" Type name
union [Criteria, ...Criteria[]] Array in which the possible criteria are listed
const schema = new Schema({
  type: "array",
  item: { type: "union", union: [{ type: "string"}, { type: "number" }]
});

Symbol

Property Type Default Description
type "symbol" Type name
symbol? symbol Symbol to check
const mySymbol = Symbol("enjoy");

const schema = new Schema({
  type: "symbol",
  symbol: mySymbol
});



Testers

String

Function Description
isAscii Check if all characters of the string are in the ASCII table.
isIp See isIpV4 and isIpV6
isIpV4 Standard: No standard
isIpV6 Standard: No standard
isEmail Standard: RFC 5321
isDomain Standard: RFC 1035
isDataURL Standard: RFC 2397
isUuid Standard: RFC 9562
isBase16 Standard: RFC 4648
isBase32 Standard: RFC 4648
isBase32Hex Standard: RFC 4648
isBase64 Standard: RFC 4648
isBase64Url Standard: RFC 4648

isIp(str:string, params: IsIpParams): boolean;
Parameter Description
prefix?: boolean Must have a prefix at the end of the IP address indicating the subnet mask.
(e.g., 192.168.0.1/22)

isEmail(str:string, params: IsEmailParams): boolean;
Parameter Description
allowQuotedString?: boolean Allows a string enclosed in quotes in the first part of the email address.
allowAddressLiteral?: boolean Allows an IPv4 or IPv6 address in place of the domain name.

isDataURL(str:string, params: IsDataUrlParams): boolean;
Parameter Description
type?: string Specifies the type of media, corresponding to the image type in the example.
(e.g., )
subtype?: string[] Specifies the sub-type of media, corresponding to the gif sub-type in the example.
(e.g., )

isUuid(str: string, params?: IsUuidParams): boolean;
Parameter Description
version?: 1|2|3|4|5|6|7 The version you wish to validate. By default, all versions are validated.

Object

Function Description
isObject Checks if it is an object.
isPlainObject Checks if it is an object but does not inherit from a native prototype. For instance, it will return false for a RegExp object.
isArray Checks if it is an array.
isFunction Checks if it is an function.
isPlainFunction Checks if it is a function but not an async, generator or async generator function. For example, an function like async () => void will return false.
isAsyncFunction Checks if it is an async function.
isGeneratorFunction Checks if it is an generator function.
isAsyncGeneratorFunction Checks if it is an async generator function.



Tools

String

Function Description
base16ToBase64 Standard : RFC 4648
Conversion of a string from base16 to a string in base64 or base64Url.
The input does not need to be in the standard, but the output will be.
base16ToBase32 Standard : RFC 4648
Conversion of a string from base16 to a string in base32 or base32Hex.
The input does not need to be in the standard, but the output will be.
base64ToBase16 Standard : RFC 4648
Conversion of a string from base64 or base64Url to a string in base16.
The input does not need to be in the standard, but the output will be.
base32ToBase16 Standard : RFC 4648
Conversion of a string from base32 or base32Hex to a string in base16.
The input does not need to be in the standard, but the output will be.
base16ToBase64(input: string, to: "B64" | "B64URL" = "B64", padding: boolean = true): string;

base16ToBase32(input: string, to: "B16" | "B16HEX" = "B16", padding: boolean = true): string;

base64ToBase16(input: string, from: "B64" | "B64URL" = "B64"): string;

base32ToBase16(input: string, from: "B16" | "B16HEX" = "B16") => string;

About

A runtime data validator in TypeScript with advanced type inference, built-in validation functions, and seamless integration for server and client environments.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published