Guardian
The idea of Guardian is as follows: the user, using guardians,
specifies a schema that the object must match and then uses parsers to check the content of the object.
const schema = G.object({    name: G.string(), // <-- guard    email: G.email("Please, enter a valid email address") // <-- guard})const objectToBeParsed = {...}const value = G.safeParse(schema, objectToBeParsed) // <-- parserif (value.ok) { // <-- check result boolean    console.log(`Object correct`, value.output) // <-- parsed object} else {    console.error(value.error) // <-- parsed error}Installation
Section titled “Installation”Metro UI already includes the Guardian library in global namespace G.
You can use it without any additional installation, but if you want to use it in your project, you can install it with package manager:
npm install @olton/guardianpnpm install @olton/guardianyarn add @olton/guardianand import it in your project:
import * as G from "@olton/guardian"or use CDN:
<script type="module">    import * as G from "https://esm.run/@olton/guardian";</script>Population
Section titled “Population”The Guardian functions stored in the global namespace named G.
const schema = G.string()try {    G.parse(schema, 123)} catch (e) {    console.error(e.message)}Guardians
Section titled “Guardians”The Guardian provides a set of functions – guardians, to create a schema for validation user input or other data.
array()
Section titled “array()”Check if the value is an array of specified type: array(guard_type, err_message?). As guard_type you can use any guardian.
const schema_array_of_strings = G.array(G.string())const schema_array_of_numbers = G.array(G.number())const schema_array_of_dates = G.array(G.date(), "Use only dates")base64()
Section titled “base64()”Check if the value is a base64 string: base64(err_message).
const schema = G.base64()between()
Section titled “between()”Check if the value is between two numbers or dates: between(min, max, err_message).
const schema = G.between(1, 10)bigint()
Section titled “bigint()”Check if the value is a bigint: bigint(err_message).
const schema = G.bigint()boolean()
Section titled “boolean()”Check if the value is a boolean: boolean(err_message).
const schema = G.boolean()bytes()
Section titled “bytes()”Check if the value is a bytes: bytes(err_message).
const schema = G.bytes()creditCard()
Section titled “creditCard()”Check if the value is a credit card: creditCard(err_message). Also you can use specified CC guardians: visa(), mastercard(), amex(), discover(), diners(), jcb(), and union().
const schema = G.creditCard()date()
Section titled “date()”Check if the value is a date object or valid date string: date(err_message).
const schema = G.date()digits()
Section titled “digits()”Check if the value contains only digits: digits(err_message).
const schema = G.digits()domain()
Section titled “domain()”Check if the value is a domain: domain(err_message).
const schema = G.domain()email()
Section titled “email()”Check if the value is an email: email(err_message).
const schema = G.email()empty()
Section titled “empty()”Check if the value is empty: empty(err_message).
const schema = G.empty()endsWith()
Section titled “endsWith()”Check if the value ends with a specified string: endsWith(str, err_message).
const schema = G.endsWith("com")finite()
Section titled “finite()”Check if the value is a finite: finite(err_message).
const schema = G.finite()float()
Section titled “float()”Check if the value is a float: float(err_message).
const schema = G.float()func()
Section titled “func()”Check if the value is a function: func(err_message).
const schema = G.func()color()
Section titled “color()”Check if the value is a:
- color(err_message)- hex, rgb, rgba, hsl, or hsla.
- hexColor(err_message)- hex.
- rgbColor(err_message)- rgb or rgba.
- hslColor(err_message)- hsl or hsla.
const schema = G.color()const schema = G.hexColor()const schema = G.rgbColor()const schema = G.hslColor()imei()
Section titled “imei()”Check if the value is an IMEI: imei(err_message).
const schema = G.imei()instance()
Section titled “instance()”Check if the value is an instance of a specified class: instance(class, err_message).
const schema = G.instance(Date)integer()
Section titled “integer()”Check if the value is an integer: integer(err_message).
const schema = G.integer()Check if the value is an IP: ip(err_message).
const schema = G.ip()length()
Section titled “length()”Check if the value has a specified length: length(val, err_message).
- length(val, err_message)- check if the value has a specified length.
- minLength(min, err_message)- check if the value has a minimum length.
- maxLength(max, err_message)- check if the value has a maximum length.
const schema = G.length(10)maxValue()
Section titled “maxValue()”Check if the value is less than a specified number: maxValue(max, err_message).
const schema = G.max(10)minValue()
Section titled “minValue()”Check if the value is greater than a specified number: minValue(min, err_message).
const schema = G.min(1)notNull()
Section titled “notNull()”Check if the value is not null: notNull(err_message).
const schema = G.notNull()notNumber()
Section titled “notNumber()”Check if the value is not a number: notNumber(err_message).
const schema = G.notNumber()number()
Section titled “number()”Check if the value is a number: number(err_message).
const schema = G.number()pattern()
Section titled “pattern()”Check if the value matches a specified pattern: pattern(regexp, err_message).
const schema = G.pattern(/^[a-z]+$/)promise()
Section titled “promise()”Check if the value is a promise: promise(err_message).
const schema = G.promise()required()
Section titled “required()”Check if the value is required: required(err_message).
const schema = G.required()safeInteger()
Section titled “safeInteger()”Check if the value is a safe integer: safeInteger(err_message).
const schema = G.safeInteger()startsWith()
Section titled “startsWith()”Check if the value starts with a specified string: startsWith(str, err_message).
const schema = G.startsWith("https://")string()
Section titled “string()”Check if the value is a string: string(err_message).
const schema = G.string()symbol()
Section titled “symbol()”Check if the value is a symbol: symbol(err_message).
const schema = G.symbol()unknown()
Section titled “unknown()”Check if the value is unknown: unknown(err_message).
const schema = G.unknown()Check if the value is a URL: url(err_message).
const schema = G.url()contains()
Section titled “contains()”Check if the value contains a specified value: contains(str, err_message). This guardian is used only for arrays and strings.
const schema = G.contains("https://")type()
Section titled “type()”Check if the value is a specified type: type(type, err_message). The type can be: string, number, array, object, null, undefined, date, function, or boolean.
const schema = G.type("string")equal()
Section titled “equal()”Check if the value is equal to a specified value: equal(val, err_message). This guard used === operator.
const schema = G.equal(10)similar()
Section titled “similar()”Check if the value is similar to a specified value: similar(val, err_message). This guard used == operator.
const schema = G.similar("10")great()
Section titled “great()”Check if the value is a great of specified value: great(val, err_message).
const schema = G.great(10)greatOrEqual()
Section titled “greatOrEqual()”Check if the value is a great or equal to specified value: greatOrEqual(val, err_message).
const schema = G.greatOrEqual(10)less()
Section titled “less()”Check if the value is a less of specified value: less(val, err_message).
const schema = G.less(10)lessOrEqual()
Section titled “lessOrEqual()”Check if the value is a less or equal to specified value: lessOrEqual(val, err_message).
const schema = G.lessOrEqual(10)object()
Section titled “object()”Create object schema: object({...}, err_message).
const schema = G.object({    name: G.string(),    email: G.email(),})Combinators
Section titled “Combinators”The Guardian provides a set of functions – combinators, to combine guardians.
pipe()
Section titled “pipe()”Run guardians left to right: pipe(guard1, guard2, ..., guardN).
const schema = G.object({    name: G.pipe(G.required(), G.string()),})compose()
Section titled “compose()”Run guardians right to left: compose(guard1, guard2, ..., guardN).
const schema = G.object({    name: G.compose(G.string(), G.required()),})Parsers
Section titled “Parsers”The Guardian provides a set of functions – parsers, to check the content of the object.
parse()
Section titled “parse()”Check the content of the object and throw an error if it is invalid: parse(schema, object).
const schema = G.string()G.parse(schema, 123) // throw errorsafeParse()
Section titled “safeParse()”Check the content of the object and return a special object with .output when all ok, and .error when invalid data: safeParse(schema, object).
const schema = G.string()const result = G.safeParse(schema, 123)
if (result.ok) {    console.log(result.output)} else {    console.error(result.error)}