Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/furstenheim/is_jsonb_valid
Native PostgreSQL extension to validate jsonb
https://github.com/furstenheim/is_jsonb_valid
Last synced: 5 days ago
JSON representation
Native PostgreSQL extension to validate jsonb
- Host: GitHub
- URL: https://github.com/furstenheim/is_jsonb_valid
- Owner: furstenheim
- License: mit
- Created: 2017-07-24T16:41:20.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-09-24T10:51:50.000Z (over 1 year ago)
- Last Synced: 2024-11-17T20:48:08.177Z (about 2 months ago)
- Language: C
- Size: 249 KB
- Stars: 165
- Watchers: 6
- Forks: 7
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
## Is jsonb valid
![Build Status](https://github.com/furstenheim/is_jsonb_valid/actions/workflows/ci.yml/badge.svg)is_jsonb_valid is a native PostgreSQL extension to validate json schemas following [Draft4](https://tools.ietf.org/html/draft-zyp-json-schema-04). and [Draft7](https://json-schema.org/draft-07/json-schema-release-notes.html)
The extension exposes two function `is_jsonb_valid(schema jsonb, data jsonb)` and `is_jsonb_valid_draft_v7(schema jsonb, data jsonb)` which return a boolean depending
on the success of the validation. `is_jsonb_valid` validates following draft 4 of json schema.Examples:
SELECT is_jsonb_valid('{"type": "number"}', '1');
> t
SELECT is_jsonb_valid('{"type": "object"}', '1');
> fSELECT is_jsonb_valid_draft_v7('{"if":{"exclusiveMaximum":0},"else":{"multipleOf":2}}', '4');
> t
SELECT is_jsonb_valid_draft_v7('{"if":{"exclusiveMaximum":0},"else":{"multipleOf":2}}', '3');
> fIt passes (most of) [JSON-Schema-Test-Suite](https://github.com/json-schema-org/JSON-Schema-Test-Suite). The exceptions are:
* $refRemote has been removed for obvious reasons.
* $ref support is limited to references nested at root, that is, something like `"$ref": "#/definitions/myschema"`. In particular, it doesn't check for `"$id"` in the chain to the root, and it doesn't support remote refs.
* format is not supported (this is optional in the draft).### Testing and Installation
Make sure that you have PostgreSQL 9.6 or newer (check ci.yml for supported versions). In the directory of the project do:
make install && make installcheck
This will compile the extension and run the tests. Later in psql run:CREATE EXTENSION is_jsonb_valid;
You can also run tests without installing postgres.
```
docker run -it --rm --mount "type=bind,src=$(pwd),dst=/repo" pgxn/pgxn-tools sh -c 'cd /repo && make clean && pg-start 12 && pg-build-test' >log 2>&1```
### Benchmarking
Benchmarking is always tricky, I've tried to check against a real world example, in particular tweets.
The only other extension that I know for this purpose is [postgres-json-schema](https://github.com/gavinwahl/postgres-json-schema/blob/master/postgres-json-schema--0.1.0.sql).
For more information on how to run the benchmarks check `./tools/README.md`| Numbers of tweets | is_jsonb_valid (ms) | postgres-json-schema (ms) | Improvement (times)
| --------------- | ---------------- | --------------- | ------- |
| 10 | 34.270 | 192.678 | 5.6 |
| 100 | 206.378 | 1975.543 | 9.6
| 10000 | 8911.354 | 203172.464 | 22.8### Disclaimer
This project is a based on postgres-json-schema. It has been written from scratch in C (original was written in SQL).