jesse (JSon Schema Erlang) is an implementation of a JSON Schema validator for Erlang.
Go to file
Alexander Dergachev 06329d42a3 Update AUTHORS file
2013-10-03 20:51:31 +02:00
doc Bump version 2013-08-27 16:12:30 +02:00
src - Change API 2013-10-03 20:51:09 +02:00
test Fix tests compatibility with R16 and later. 2013-04-15 17:11:35 +04:00
.gitignore Update .gitignore 2013-02-19 18:57:37 +01:00
.gitmodules Add JSON-Schema-Test-Suite as a submodule 2013-02-19 18:57:37 +01:00
.travis.yml Add a new line in the end of the file in .travis.yml 2013-04-23 21:00:05 +02:00
AUTHORS Update AUTHORS file 2013-10-03 20:51:31 +02:00
CHANGELOG.md Add support for jsx format 2013-02-23 09:57:25 +01:00
cover.spec Add cover.spec 2013-02-19 18:57:37 +01:00
LICENSE Remove unnecessary text from LICENSE file 2013-02-19 18:57:38 +01:00
Makefile Init submodules only when make target 'test' #2 2013-02-23 09:04:51 +01:00
NOTICE Add NOTICE file 2013-02-19 18:57:38 +01:00
README.md Add configuration for travis (https://secure.travis-ci.org/) 2013-04-23 20:54:21 +02:00
rebar Initial commit 2012-06-18 17:57:59 +02:00
rebar.config Add additional configuration for eunit to rebar.config 2013-02-19 18:57:37 +01:00
rebar.tests.config Add rebar.tests.config 2013-02-19 18:57:37 +01:00

===== jesse Build Status

jesse (JSon Schema Erlang) is an implementation of a json schema validator for Erlang.

jesse implements [Draft 03] (http://tools.ietf.org/html/draft-zyp-json-schema-03) of the specification. It supports almost all core schema definitions except:

  • format
  • $ref

Quick start

There are two ways of using jesse:

  • to use jesse internal in-memory storage to keep all your schema definitions In this case jesse will look up a schema definition in its own storage, and then validate given json.
  • it is also possible to provide jesse with schema definitions when jesse is called.

Examples

NOTE: jesse doesn't have any parsing functionality. It currently works with three
      formats: mochijson2, jiffy and jsx, so json needs to be parsed in advance,
      or you can specify a callback which jesse will use to parse json.

      In examples below and in jesse test suite jiffy parser is used.
  • Use jesse's internal in-memory storage:

(parse json in advance)

1> Schema = jiffy:decode(<<"{\"items\": {\"type\": \"integer\"}}">>).
{[{<<"items">>,{[{<<"type">>,<<"integer">>}]}}]}
2> jesse:add_schema(some_key, Schema).
ok
3> Json1 = jiffy:decode(<<"[1, 2, 3]">>).
[1,2,3]
4> jesse:validate(some_key, Json1).
{ok,[1,2,3]}
5> Json2 = jiffy:decode(<<"[1, \"x\"]">>).
[1,<<"x">>]
6> jesse:validate(some_key, Json2).
{error,{data_invalid,<<"x">>,not_integer,
                     {[{<<"type">>,<<"integer">>}]}}}"]")

(using a callback)

1> jesse:add_schema(some_key,
1>                  <<"{\"uniqueItems\": true}">>,
1>                  fun jiffy:decode/1).
ok
2> jesse:validate(some_key,
2>                <<"[1, 2]">>,
2>                fun jiffy:decode/1).
{ok,[1,2]}
3> jesse:validate(some_key,
3>                <<"[{\"foo\": \"bar\"}, {\"foo\": \"bar\"}] ">>,
3>                fun jiffy:decode/1).
{error,{data_invalid,[{[{<<"foo">>,<<"bar">>}]},
                      {[{<<"foo">>,<<"bar">>}]}],
                     {{[{<<"foo">>,<<"bar">>}]},not_unique},
                     {uniqueItems,true}}}
  • Call jesse with schema definition in place (do not use internal storage)

(parse json in advance)

1> Schema = jiffy:decode(<<"{\"pattern\": \"^a*$\"}">>).
{[{<<"pattern">>,<<"^a*$">>}]}
2> Json1 = jiffy:decode(<<"\"aaa\"">>).
<<"aaa">>
3> jesse:validate_with_schema(Schema, Json1).
{ok,<<"aaa">>}
4> Json2 = jiffy:decode(<<"\"abc\"">>).
<<"abc">>
5> jesse:validate_with_schema(Schema, Json2).
{error,{data_invalid,<<"abc">>,no_match,<<"^a*$">>}}

(using a callback)

1> Schema = <<"{\"patternProperties\": {\"f.*o\": {\"type\": \"integer\"}}}">>.
<<"{\"patternProperties\": {\"f.*o\": {\"type\": \"integer\"}}}">>
2> jesse:validate_with_schema(Schema,
2>                            <<"{\"foo\": 1, \"foooooo\" : 2}">>,
2>                            fun jiffy:decode/1).
{ok,{[{<<"foo">>,1},{<<"foooooo">>,2}]}}
3> jesse:validate_with_schema(Schema,
3>                            <<"{\"foo\": \"bar\", \"fooooo\": 2}">>,
3>                            fun jiffy:decode/1).
{error,{data_invalid,<<"bar">>,not_integer,
                     {[{<<"type">>,<<"integer">>}]}}}""}]""}")

Caveats

  • pattern and patternProperty attributes:

    jesse uses standard erlang module re for regexp matching, therefore there could be some incompatible regular expressions in schemas you define.

    From erlang docs: "re's matching algorithms are currently based on the PCRE library, but not all of the PCRE library is interfaced"

    But most of common cases should work fine.

Contributing

If you see something missing or incorrect, a pull request is most welcome!