Skip to main content

Lightweight WSGI application framework, schema-validated JSON APIs, and API documentation

Project description

PyPI - Status PyPI GitHub PyPI - Python Version

Chisel is a light-weight Python WSGI application framework built for creating well-documented, schema-validated JSON web APIs.

JSON APIs

Chisel provides the action decorator for easily implementing schema-validated JSON APIs.

>>> @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 defines an action definition using Schema Markdown. The action callback is passed two arguments, a request Context and the schema-validated request input dictionary. The input request dictionary is created by combining the request’s URL path parameters, query string parameters, and input JSON content parameters.

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 to your application by adding the Chisel documentation application requests from create_doc_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.

Development

This package is developed using python-build. It was started using python-template as follows:

template-specialize python-template/template/ chisel/ -k package chisel -k name 'Craig A. Hobbs' -k email 'craigahobbs@gmail.com' -k github 'craigahobbs' -k nomain 1

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-1.2.4.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

chisel-1.2.4-py3-none-any.whl (17.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: chisel-1.2.4.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for chisel-1.2.4.tar.gz
Algorithm Hash digest
SHA256 bf658f5a70a528e6a612f15c725a84b7094ea45629f10b6dfe0d0d5053e21cc9
MD5 fc310c08ae9863faa1028038981dd503
BLAKE2b-256 d2317a267b2b18479f6628934e53d5ab46d31b271a7e9a8ca15b0568e72c5f3b

See more details on using hashes here.

File details

Details for the file chisel-1.2.4-py3-none-any.whl.

File metadata

  • Download URL: chisel-1.2.4-py3-none-any.whl
  • Upload date:
  • Size: 17.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for chisel-1.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b46d9e98fdf2b10ce903677d5b5ac5709ea616a6ffe9465a4ac69e3bbcefbcc1
MD5 1677db98d028c0069018c598f78fb30c
BLAKE2b-256 0e4a90e5f5ff656d9baec8f97f966cae147db14b16df5047c1d8b579df2761e6

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