json-inspector

1.0.0-rc.2 • Public • Published

JSON Inspector

Build Status Test Coverage

Json Inspector is json data validator & sanitizer. It allows you to define validation rules for complex data structures by simple and descriptive way of defining json-compliant inspector schema.

Installation

npm install json-inspector

or

bower install json-inspector

... or you can browserify your own bundle for a browser, see npm run-script build in the package.json

Features

  • Complex data structures validation & sanitization
  • Extremely simple schema definition
  • Multilanguage support for error messages
  • Filtering of data
  • Custom assertion & sanitizer implementations (extensible)
  • Conditional data validation (suitable for eg. complicated permission handling)
  • Express support
  • Referencing other schema definitions from within a schema
  • And more! (see Documentation for all available options)

Resources

Simple schema definition example

inspector.define('user', {
    username: {
        $nullable: true,
        $isAlphanumeric: 'en-US',
        $hasLengthOf: {max: 32}
    },
    email: {
        $required: true,
        $isEmail: {allow_display_name: true}
    },
    address: {
        street: {
            $is: String
        },
        zip: {
            $isInt: {min: 1}
        }
    },
    apps: {
        $forEach: {
            name: {
                $in: ['app1', 'app2']
            }
        }
    }
});

Cons

The JsonInspector can't validate object's properties which have matching names with one of the schema definition keywords (those data properties are removed by default). This intentional design decision limits universality of the library in exchange for improved schema readability and simplicity (less code). The issue is partialy solved by the keyword prefix feature which allows you to dynamically change a prefix string of keywords (which defaults to the $ character). In practice, you most probably won't ecnouter this limitation (if you were to, you would have known by now).
If this limitation is a deal breaker, consider trying out the ajv validation library.

Tests

npm run-script tests

NOTE: The most of the actual data validation is handed over to the chriso validation library.

Dependencies (4)

Dev Dependencies (9)

Package Sidebar

Install

npm i json-inspector

Weekly Downloads

0

Version

1.0.0-rc.2

License

GPL-3.0

Last publish

Collaborators

  • fogine