tree-validator

A simple validator for JSON Trees with error reporting. Written in coffee

Usage no npm install needed!

<script type="module">
  import treeValidator from 'https://cdn.skypack.dev/tree-validator';
</script>

README

TreeValidator

A simple validator for JSON Trees with error reporting. Written in coffee

Installation

  npm install --save tree-validator

Usage

  TreeValidator = require("./treeValidator");
  validator = new TreeValidator();
  
  config = {
    type: "string",
    minLength: 3,
    maxLength: 32,
    trim: true
  };
  
  testValue = "Lisa Simpson    ";
  
  console.log validator.validate(testValue,config);
  
  

Result

If the validation succeeds, the validator returns an object as follows:

  {
    "status": true,
    "value": "Lisa Simpson"
  }

If something goes wrong, the result may look like this:

  testValue = "fo";
  {
    "status": false,
    "error": "minLength",
    "path": ""
  }

Example of all types

// dist/example.js
config = {
  type: "object",
  childprops: {
    name: { type: "string", minLength: 3, maxLength: 32, trim: true },
    age: { type: "int", min: 0 },
    children: {
      type: "array",
      maxLength: 10,
      items: {
        type: "object",
        childprops: {
          name: { type: "string", minLength: 3, maxLength: 32 },
          age: { type: "int", min: 0, max: 100 },
          toys: {
            type: "array",
            items: { type: "string", trim: "true" }
          }
        }
      }
    }
  }
};

testItem = {
  name: "John",
  age: 13,
  children: [
    {
      name: "Max",
      age: 2,
      toys: ["Car", "Barbie"]
    }, {
      name: "Lisa",
      age: 13,
      toys: ["Car", "Potatoe"]
    }
  ]
};

console.log(JSON.stringify(validator.validate(testItem, config), null, 4));

Types

The validator supports the following types

String

  {
    type: "string",
    trim: boolean, // Trim is ran before min-&maxLength
    minLength: int,
    maxLength: int,
  }

Int

  {
    type: "string",
    // If this is true Math.min() and Math.max() are used to change the value entered to fit the given range 
    // Else an error is thrown
    enforceMax: boolean, 
    
    min: int,
    max: int,
  }

Boolean

Convert a value to boolean. Always.

  { 
    type: "boolean"
  
  }

Array -- Allows nesting

Iterates over items and applies validation against the items of the array

  { 
    type: "array",
    maxLength: int,
    items: {
      [ Child config ] // This is a new config tree 
    }
  }

Object -- Allows nesting

This filters out all properties from an object, and applies validation against the values.

  {
    type: "object"
    childprops: {
      [PROPNAME]: [ Child config ] // This a new config tree
    }
  }