Skip to main content

Light-weight WSGI application framework, schema-validated JSON APIs, and API documentation.

Project description

PyPI - Status PyPI

Travis (.org) Codecov

GitHub PyPI - Python Version

Chisel is a light-weight Python WSGI application framework with tools for building well-documented, schema-validated JSON web APIs. Here are Chisel’s features at a glance:

  • Light-weight WSGI application framework

  • Schema-validated JSON web APIs

  • Schema-accurate API documentation

  • Written in pure Python

  • Zero dependencies

  • Python 3.7+

Overview

To create a Chisel application, first create an Application object. Add functionality to your application by adding request objects to using the application’s add_request method. A Request object is itself a WSGI application with metadata such as the HTTP request method and URL path at which to serve the request.

>>> from http import HTTPStatus
...
>>> @chisel.request(urls=[('GET', None)])
... def hello_world(environ, start_response):
...     ctx = environ[chisel.Context.ENVIRON_CTX]
...     return ctx.response_text(HTTPStatus.OK, 'Hello, World!')
...
>>> application = chisel.Application()
>>> application.add_request(hello_world)
>>> application.request('GET', '/hello_world')
('200 OK', [('Content-Type', 'text/plain')], b'Hello, World!')

Schema-Validated JSON APIs

Chisel provides a built-in Request sub-class for easily implementing schema-validated JSON APIs called “actions”. To define an, action use the action decorator to wrap an action callback function. For example:

>>> @chisel.action(spec='''
... # Sum a list of numbers
... action sum_numbers
...     urls
...        GET
...
...     query
...         # The list of numbers
...         float[len > 0] numbers
...
...     output
...         # The sum of the numbers
...         float sum
... ''')
... def sum_numbers(ctx, req):
...     return {'sum': sum(req['numbers'])}
...
>>> application = chisel.Application()
>>> application.add_request(sum_numbers)
>>> application.request('GET', '/sum_numbers', query_string='numbers.0=1&numbers.1=2&numbers.2=4')
('200 OK', [('Content-Type', 'application/json')], b'{"sum":7.0}')

Each action must define an action specification using the Chisel Specification Language. The easiest way to define the action specification is to provide the “spec” argument to the action decorator as above. The action callback is passed two arguments, a request Context and the schema-validated request input object. The input request object is created by combining the request’s URL path parameters, query string parameters, and input JSON content parameters.

In the example above, notice that the code does not check the input request object before using it. This is OK in a chisel action callback because the input request object is validated prior to calling the callback. If there is a schema validation error the appropriate error code is automatically returned.

>>> status, _, content_bytes = application.request('GET', '/sum_numbers')
>>> status
'400 Bad Request'
>>> content_bytes
b'{"error":"InvalidInput","message":"Required member \'numbers\' missing (query string)"}'

API Documentation

You can add API documentation by adding the Chisel documentation application to your application using create_doc_requests and add_requests.

>>> application = chisel.Application()
>>> application.add_requests(chisel.create_doc_requests())

By default the documentation application is hosted at “/doc/”. An example of of Chisel’s documentation output is available here.

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

chisel-0.9.112.tar.gz (52.1 kB view details)

Uploaded Source

File details

Details for the file chisel-0.9.112.tar.gz.

File metadata

  • Download URL: chisel-0.9.112.tar.gz
  • Upload date:
  • Size: 52.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.6.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for chisel-0.9.112.tar.gz
Algorithm Hash digest
SHA256 6820fa1f97234811c944c27d2fa01bae0494cf644095ced84f20ad6a7e0057e3
MD5 b2dc6ce95ed0b168835368e8c23f81e9
BLAKE2b-256 8a8302effac94886e2409f6e1fce0cddc98835341d87d1a6d803760dfe3c797e

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