Skip to main content

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

Project description

chisel

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.

Links

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')

'400 Bad Request'
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

This version

1.3.5

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

Uploaded Source

Built Distribution

chisel-1.3.5-py3-none-any.whl (19.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: chisel-1.3.5.tar.gz
  • Upload date:
  • Size: 17.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.13.0rc3

File hashes

Hashes for chisel-1.3.5.tar.gz
Algorithm Hash digest
SHA256 13f05fb4bb516f28debe2120b0581a4c9f627419f1a812cdd5ff6b7a4a5d1f73
MD5 0354ce2c46b0f0d0282d181d2bf43174
BLAKE2b-256 6f5c3c3bef060c99f8ce001b9e3cfa711a3a8314eaf1aeb5750dea44aae6dfeb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: chisel-1.3.5-py3-none-any.whl
  • Upload date:
  • Size: 19.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.13.0rc3

File hashes

Hashes for chisel-1.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 de730a95ac059770608050ed665f40519c4b13d3ee77893a4e59c928a4cd04de
MD5 900606bd2e8d16ef77b266f1399faca5
BLAKE2b-256 d388223ba46a8ab689e35bb3ee5f8d1a45cf0b4c5679cfc63051178db9d11979

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