json-schema-compatibility

JSON Schema tools are now being written for v4 of the draft, but v3 schemas still exist out in the wild.

Downloads in past

Stats

StarsIssuesVersionUpdatedCreatedSize
json-schema-compatibility
1.1.07 years ago8 years agoMinified + gzip package size for json-schema-compatibility in KB

Readme

JSON Schema compatibility
JSON Schema tools are now being written for v4 of the draft, but v3 schemas still exist out in the wild.
This project intends to be a converter that updates schemas to be compatible with v4 of the spec.

Behaviour

This tool works "in-place" - so it actually modifies the JavaScript objects representing the schema. This is simply because it's easier than cloning the data or anything like that.
This tool should also not modify schemas that are already compatible, and can even (in some cases) handle horrible merged combinations (e.g. mixed boolean/array use of required).

Usage (Node):

Install using npm:
npm install json-schema-compatibility

Convert a schema:
var api = require('json-schema-compatibility');

api.v4(oldSchema);

Usage (browser)

This has not been thoroughly tested, but it should make the API available as a global JsonSchemaCompatibility variable.
You might need a shim to get it to work in older browsers (due to use of Array.isArray() etc), but I'd imagine any JSON Schema validator would already include/require that.

Combination with other packages

The idea is that you can take your v3 schemas, and pass them through this tool before handing them to a v4 utility. For instance, using tv4:
var oldSchema = {"type": "number", "divisibleBy": 1.5};
var v4Schema = JsonSchemaCompatibility.v4(oldSchema);

tv4.validate(data, v4Schema);

License

The code is available as "public domain", meaning that it is completely free to use, without any restrictions at all. Read the full license here.
It's also available under an MIT license.