Skip to main content

Wrap a WSGI application in an AWS Lambda handler function for running on API Gateway or an ALB.

Project description

https://img.shields.io/github/workflow/status/adamchainz/apig-wsgi/CI/main?style=for-the-badge https://img.shields.io/codecov/c/github/adamchainz/apig-wsgi/main?style=for-the-badge https://img.shields.io/pypi/v/apig-wsgi.svg?style=for-the-badge https://img.shields.io/badge/code%20style-black-000000.svg?style=for-the-badge pre-commit

Wrap a WSGI application in an AWS Lambda handler function for running on API Gateway or an ALB.

A quick example:

from apig_wsgi import make_lambda_handler
from myapp.wsgi import app

# Configure this as your entry point in AWS Lambda
lambda_handler = make_lambda_handler(app)

Installation

Use pip:

python -m pip install apig-wsgi

Python 3.6 to 3.10 supported.


Deploying a Django Project? Check out my book Speed Up Your Django Tests which covers loads of best practices so you can write faster, more accurate tests.


Usage

Use apig-wsgi in your lambda function that you attach to one of:

  • An ALB.

  • An API Gateway “REST API”.

  • An API Gateway “HTTP API”.

Both “format version 1” and “format version 2” are supported (documentation). apig-wsgi will automatically detect the version in use. At time of writing, “format version 2” is only supported on HTTP API’s.

make_lambda_handler(app, binary_support=None, non_binary_content_type_prefixes=None)

app should be a WSGI app, for example from Django’s wsgi.py or Flask’s Flask() object.

binary_support configures whether responses containing binary are supported. The default, None, means to automatically detect this from the format version of the event - on it defaults to True for format version 2, and False for format version 1. Depending on how you’re deploying your lambda function, you may need extra configuration before you can enable binary responses:

  • ALB’s support binary responses by default.

  • API Gateway HTTP API’s support binary responses by default (and default to event format version 2).

  • API Gateway REST API’s (the “old” style) require you to add '*/*' in the “binary media types” configuration. You will need to configure this through API Gateway directly, CloudFormation, SAM, or whatever tool your project is using. Whilst this supports a list of binary media types, using '*/*' is the best way to configure it, since it is used to match the request ‘Accept’ header as well, which WSGI applications often ignore. You may need to delete and recreate your stages for this value to be copied over.

Note that binary responses aren’t sent if your response has a ‘Content-Type’ starting ‘text/’, ‘application/json’ or ‘application/vnd.api+json’ - this is to support sending larger text responses, since the base64 encoding would otherwise inflate the content length. To avoid base64 encoding other content types, you can set non_binary_content_type_prefixes to a list of content type prefixes of your choice (which replaces the default list).

If the event from API Gateway contains the requestContext key, for example on format version 2 or from custom request authorizers, this will be available in the WSGI environ at the key apig_wsgi.request_context.

If you want to inspect the full event from API Gateway, it’s available in the WSGI environ at the key apig_wsgi.full_event.

If you need the Lambda Context object, it’s available in the WSGI environ at the key apig_wsgi.context.

If you’re using “format version 1”, multiple values for request and response headers and query parameters are supported. They are enabled automatically on API Gateway but need explict activation on ALB’s. If you need to determine from within your application if multiple header values are enabled, you can can check the apgi_wsgi.multi_value_headers key in the WSGI environ, which is True if they are enabled and False otherwise.

Example

An example application with Ansible deployment is provided in the example/ directory in the repository. See the README.rst there for guidance.

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

apig-wsgi-2.11.0.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

apig_wsgi-2.11.0-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file apig-wsgi-2.11.0.tar.gz.

File metadata

  • Download URL: apig-wsgi-2.11.0.tar.gz
  • Upload date:
  • Size: 9.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for apig-wsgi-2.11.0.tar.gz
Algorithm Hash digest
SHA256 ede695a1b9e70e572b0faaccc74e02e7c4704c585e11e8d42b87f561c8055f39
MD5 809b6232df4d9f9262a93d62b56795de
BLAKE2b-256 16ca75d31dace21b5599882f187e59fe1829b67a524cd8d8a5ad10ed9bb8ee17

See more details on using hashes here.

File details

Details for the file apig_wsgi-2.11.0-py3-none-any.whl.

File metadata

  • Download URL: apig_wsgi-2.11.0-py3-none-any.whl
  • Upload date:
  • Size: 7.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for apig_wsgi-2.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e119f5ff69c0d400c9c417b0cca62eaceb4acbf8090308c4080a90fbbbf8014b
MD5 299f00d278ebb7402d56256d24ec5ec8
BLAKE2b-256 49285a4a9654475f2e2e60de5cc81b0dcc229d9c79ddbaea54ab808f10a62c3c

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