JSON Schema Utils
Project description
JSON Schema Utils
Random utilities to analyze, manipulate, simplify, convert or compile JSON Schema.
Installation
Install latest version with pip from
PyPI or directly from
GitHub:
python -m venv venv
source venv/bin/activate
# from PyPI:
pip install json_schema_utils
# OR from latest sources:
pip install git+https://github.com/zx80/json-schema-utils.git
Inline Schema References
Replace references $ref by their definitions.
# no $id
jsu-inline -m "file:// ./tests" tests/*.schema.json
# with $id
jsu-inline -a tests/foo.schema.json
Simplify Schema
Apply various schema simplifications:
- remove type-incompatible keywords and formats, with warnings.
- try to move up list-of-one-schema
*Of. - simplify type lists.
- change list-of-one
enumtoconst. - detect some cases of infeasible schemas.
- remove uneffective keywords in corner cases.
jsu-simpler tests/*.schema.json
Check JSON Values against a Schema
Check a JSON values match a given schema using
jmc (jsu-compile with
jmc dynamic Python backend),
jsonschema or
jschon
implementations.
jsu-check tests/foo.schema.json tests/foo.*.value.json
Note: the corresponding external dependencies must be installed.
JSON Schema Stats and Issues
Generate a report about JSON schemas, including possible bugs.
jsu-stats tests/*.schema.json
This script is extracted from JSON Schema Stats which has been updated to depend on this module.
JSON Prettyprinter
jsu-pretty --indent 2 --sort-keys tests/*.schema.json
You could also use jq . for this purpose.
JSON Schema to JSON Model Conversion
Convert a subset of JSON Schema to JSON Model.
The converter is expected to fully supports JSON Schema draft3 to draft7.
It partially supports draft 2019-09 and 2020-12, in particular there is a limited support for some features:
- dynamic anchors and references;
- unevaluated stuff;
- vocabularies;
Moreover, this is a software, hence there may be bugs.
jsu-model -o foo.model.json foo.schema.json
JSON Schema Compiler
Convert the input schema and generate C, JS, Python, Java, Perl or even PL/pgSQL code.
The compiler first converts the schema to a model (see previous command), then proceeds to compile the generated model to actual code using the JSON Model Compiler as a backend.
# generate a python script
jsu-compile -o some.py some.schema.json
# run the script to validate values
./some.py val1.json val2.json
The generated code (here the some.py Python script) needs some runtime which
is installed with the compiler python module.
Other languages require specific runtimes, which are available in the
docker.io/zx80/jmc container image, or can be installed independently,
see JSON Model HOWTO.
TODO
- propagate non type under containers (
*Of,if,then,else, reference?) to reduce false positive errors/warnings. - simplify: deduplicate constants in enum?
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file json_schema_utils-0.9.1.tar.gz.
File metadata
- Download URL: json_schema_utils-0.9.1.tar.gz
- Upload date:
- Size: 70.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b759a2d50a9ee2035f701fd318651e55ee97dc386b7c7db245f0fc1fa3a9474
|
|
| MD5 |
0a21c793064307a31c08fed190a6067a
|
|
| BLAKE2b-256 |
c8cd7c2967cbad1d3e6276701e4c24efb60a2018f0a55bcd6101545fec8614e8
|
File details
Details for the file json_schema_utils-0.9.1-py3-none-any.whl.
File metadata
- Download URL: json_schema_utils-0.9.1-py3-none-any.whl
- Upload date:
- Size: 67.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bb1e2f5901d2076bbdfaece6bf9d8a101ce603b28435e0b65e6e63cfcd6ce1f0
|
|
| MD5 |
feb22ed1e9c10edf2bcd724e59bf10cc
|
|
| BLAKE2b-256 |
870af9b1011cbf21bf4007d17fd007f7a538908f4c2177274d532c4506933b8d
|