Neovictorian Paisley Menswear


    1.1.0 • Public • Published

    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.


    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');

    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);


    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.


    npm i json-schema-compatibility

    DownloadsWeekly Downloads






    Last publish


    • geraintluff