Skip to main content

Validation and parsing library

Project description

Trafaret Schema
===============

[![Build status](https://circleci.com/gh/Deepwalker/trafaret_schema.svg?style=shield)](https://circleci.com/gh/Deepwalker/trafaret_schema)
[![Gitter](https://badges.gitter.im/Deepwalker/trafaret.png)](https://gitter.im/Deepwalker/trafaret)
[![Downloads](https://img.shields.io/pypi/v/trafaret_schema.svg?style=flat-square)](https://pypi-hypernode.com/pypi/trafaret_schema)
[![Downloads](https://img.shields.io/pypi/l/trafaret_schema.svg?style=flat-square)](https://pypi-hypernode.com/pypi/trafaret_schema)


Library takes JSON Schema and converts it to a Trafaret instance:

from trafaret_schema import json_schema
check_string = json_schema({'type': 'string', 'minLength': 6, 'maxLength': 10, 'pattern': '(bla)+'})
check_string('blablabla')

What is important to note, that this library is a big trafaret that produces other trafarets. So on parsing
JSON Schema you can get a DataError, and you will get DataError in usage of parsed schema.
And you can use schema parser or parsed schema as trafaret in any circumstances where you can use trafarets.

You can use `Register` object to provide custom `format` implementation and to support cross schemas `$ref`
objects:

import trafaret as t
from trafaret_schema import json_schema, Register

my_reg = Register()

my_reg.reg_format('any_ip', t.IPv4 | t.IPv6)

check_address = json_schema(open('address.json').read(), context=register)
check_person = json_schema(open('person.json').read(), context=register)


Library is a bit of fun, because it is implemented in a `trafaret` and produces `trafaret` instances. Also its like
a pro level of `trafaret` usage (I hope so).

Features:

[*] basic
[*] type
[*] enum
[*] const
[*] number
[*] string
[*] array
[*] minProperties
[*] maxProperties
[*] uniqueItems
[*] items
[*] additionalItems
[*] contains
[*] objects
[*] maxProperties
[*] minProperties
[*] required
[*] properties
[*] patternProperties
[*] additionalProperties
[*] dependencies
[*] propertyNames
[*] combinators
[*] anyOf
[*] allOf
[*] oneOf
[*] not
[*] format
[*] references
[*] definitions
[*] $ref

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

trafaret_schema-0.2.1.tar.gz (7.5 kB view details)

Uploaded Source

Built Distribution

trafaret_schema-0.2.1-py3-none-any.whl (9.3 kB view details)

Uploaded Python 3

File details

Details for the file trafaret_schema-0.2.1.tar.gz.

File metadata

File hashes

Hashes for trafaret_schema-0.2.1.tar.gz
Algorithm Hash digest
SHA256 24deed069b7a7065a112f8ed9aa55e227cd892578c9547de5356f2661d4f727d
MD5 2f53739b1394a779ba9b772f591c4760
BLAKE2b-256 28e2eab9650c6e04a00ff57fc38306e2e66a2762c65c98fe683058af48367644

See more details on using hashes here.

File details

Details for the file trafaret_schema-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for trafaret_schema-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 47a6dc28dcb68ae1191495eec8fd52acebb7c15eb7ec7fd8da092f55a111bfdf
MD5 32bd241f2eebd27181997b945954998d
BLAKE2b-256 2bfa3bdfc83894236dc56d548144f3a8fb0c8527224d00a56a5d3f50501ed08c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page