Skip to main content

Python data validation with web in-mind

Project description

https://travis-ci.org/baverman/covador.svg?branch=master https://img.shields.io/badge/coverage-100%25-brightgreen.svg https://img.shields.io/badge/python-2.7%2C_3.4%2C_3.5%2C_3.6%2C_pypy-blue.svg

Validation library for processing http endpoint arguments.

from flask import Flask

from covador import split, opt
from covador.flask import query_string

app = Flask(__name__)

@app.route('/')
@query_string(foo=opt(split(int), []))
def csv_argument(foo):
    return repr(foo)

# GET /?foo=1,2,3 -> [1, 2, 3]

if __name__ == '__main__':
    app.run()
  • Support for flask, django, aiohttp, tornado and sanic.

  • Simple creating of custom query_string/form/params/json_body/rparams wrappers.

  • Multi dict support via item multi param.

  • Multi dict keys support via item src param.

  • Simple interface for custom validators/processors it’s just a callable.

  • Maps, typed Maps, Lists, Tuples, Enums.

  • Validation chains: opt(default=[]) | split(separator=' ') | List(int) | (lambda it: it[:10]) or more concise opt(split(int, separator=' '), []) | operator.itemgetter(slice(10)) — an optional argument of space separated integers and we need top 10 items from it and it is empty by default.

  • Literal schema: schema(foo=[{'boo': int}]), validates {'foo': [{'boo': 10}, {'boo': 20}]}.

  • Bytes/unicode aware.

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

covador-0.9.16.tar.gz (10.5 kB view hashes)

Uploaded Source

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