Skip to main content

Chalice x APISpec x Pydantic plug-ins

Project description

chalice-spec

Python package Code style: black

Chalice × APISpec × Pydantic plug-ins

Combines the power of Chalice, APISpec, and Pydantic to make AWS Chalice apps easily documented

Installation

First, add chalice-spec:

poetry add chalice_spec

We consider Chalice, APISpec, and Pydantic "peer dependencies." We only include them as dev dependencies in our codebase, and you may need to install them in yours if you haven't already.

poetry add chalice apispec pydantic

Setup

chalice-spec provides a subclass of the main Chalice class, called ChaliceWithSpec. Here is an example of how to get started:

Before:

from chalice import Chalice

app = Chalice(app_name="hello_world")

After:

from chalice_spec import ChaliceWithSpec, PydanticPlugin
from apispec import APISpec

spec = APISpec(...,
               plugins=[PydanticPlugin()])

app = ChaliceWithSpec(app_name="hello_world", spec=spec)

If you use

ChaliceWithSpec(..., generate_default_docs=True)

the plugin will generate empty docs (with empty request and response schemas) for every endpoint that you've defined in your app. This can be useful as a starting point / overview while developing.

Usage

To document your API, use your existing Pydantic models and add kwargs to Chalice decorators.

Before:

@app.route('/', methods=["POST"])
def example():
    body = MySchema.parse_obj(app.current_request.json_body)

After:

@app.route('/', methods=["POST"], docs=Docs(
    post=Operation(request=MySchema)
))
def example():
    body = MySchema.parse_obj(app.current_request.json_body)

If you have multiple methods supported, you may have something like:

@app.route('/', methods=["POST", "PUT"],
           docs=Docs(
               post=Operation(request=MyCreateSchema, response=MyReadSchema),
               put=Operation(request=MyEditSchema, response=MyReadSchema)
           )
def example():
    # code goes here
    pass

Auto-Generation

Default Empty Docs

If you use:

ChalicePlugin(generate_default_docs=True)

the plugin will generate empty docs (with empty request and response schemas) for every endpoint that you've defined in your app. This can be useful as a starting point / overview while developing.

Path Parameters

These are inferred from the path itself. Any identifiers inside curly braces in a path is added as a string path parameter for that path. e.g. for the path /users/{id}/friends/{f_id}, the path parameters id and f_id will be added to the spec.

To disable this behaviour, define your own parameters or set them to an empty list:

Operation(request=MySchema, response=MyOtherSchema, parameters=[])

Tags

Tags are used in things like Swagger to group endpoints into logical sets. If you don't supply any tags, chalice-spec will add a tag for each endpoint that is the first segment of the path. e.g. /users, /users/{id}/friends, and /users/{id}/posts will all be tagged with users.

To disable this behaviour, define tags in your operation (either with the tags you want, or an empty list):

Operation(request=MySchema, response=MyOtherSchema, tags=[])

Summary and Description

Endpoint summaries and descriptions are inferred from the route docstring. The first line of the docstring is used as the summary, and all other lines become the description:

@app.route('/users/{id}', methods=['GET'], docs=Docs(response=UserSchema))
def get_user(id):
    """
    Retrieve a user object.
    User's can't retrieve other users using this endpoint - only themselves.
    """

To disable this behaviour, you can define your own summary/description or set them to empty strings:

Operation(request=MySchema, response=MyOtherSchema, summary='', description='')

API

  • TODO: this section coming soon!

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

chalice_spec-0.7.0.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

chalice_spec-0.7.0-py3-none-any.whl (10.8 kB view details)

Uploaded Python 3

File details

Details for the file chalice_spec-0.7.0.tar.gz.

File metadata

  • Download URL: chalice_spec-0.7.0.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.11.0 Darwin/22.5.0

File hashes

Hashes for chalice_spec-0.7.0.tar.gz
Algorithm Hash digest
SHA256 0601850b6fa10f1834e3036115d920d14d31c4871431b0bc11971a810fb459c6
MD5 a97251697c7a65ff0be7f5b3b19aa365
BLAKE2b-256 9f9e9b59a6d8547150461e926d862f6db60d7322c002cbe76d8827cd795aae5b

See more details on using hashes here.

File details

Details for the file chalice_spec-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: chalice_spec-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 10.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.11.0 Darwin/22.5.0

File hashes

Hashes for chalice_spec-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a9cebb7686e7555d348568f72e7a0ca2b3c400857226d7cfe003342e1e867cf2
MD5 5b47ceff15f755b97dbc49492079a34b
BLAKE2b-256 110bd756d40277a1eebd69ee2760ea7948c48932d875d0ef9d37c3dc1bb745f3

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