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

Download files

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

Source Distribution

chisel-2.0.4.tar.gz (151.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

chisel-2.0.4-py3-none-any.whl (151.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: chisel-2.0.4.tar.gz
  • Upload date:
  • Size: 151.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for chisel-2.0.4.tar.gz
Algorithm Hash digest
SHA256 0b466f7c71d938c8ad69c629970aa9dbe6055fc7d9fe370136c058fb7f472c15
MD5 6dc23d9badaae0ad97e2810560e5d3b5
BLAKE2b-256 0fc91d5a4fa7e078102c2f6f3479c0f37bc9c92df180dd5f4e935f9a7a0ba278

See more details on using hashes here.

File details

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

File metadata

  • Download URL: chisel-2.0.4-py3-none-any.whl
  • Upload date:
  • Size: 151.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for chisel-2.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b58dfd3aea7417cb43fc4a4438bb5e9bec72f7506cc3e19ad9316efeae00abb3
MD5 0d07868a18d119aff3589fa855d94769
BLAKE2b-256 a22281f19058438dacb9d17fefb6e16d1d6cae37cdd224f63a026ddb043743ce

See more details on using hashes here.

Supported by

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