Skip to main content

Adapter to running ASGI applications on aiohttp

Project description

aiohttp-asgi

PyPI - License Wheel PyPI PyPI Coverage Status tox

This module provides a way to use any ASGI compatible frameworks and aiohttp together.

Example

from aiohttp import web
from fastapi import FastAPI
from starlette.requests import Request as ASGIRequest

from aiohttp_asgi import ASGIResource


asgi_app = FastAPI()


@asgi_app.get("/asgi")
async def root(request: ASGIRequest):
    return {
        "message": "Hello World",
        "root_path": request.scope.get("root_path")
    }


aiohttp_app = web.Application()

# Create ASGIResource which handle
# any request startswith "/asgi"
asgi_resource = ASGIResource(asgi_app, root_path="/asgi")

# Register resource
aiohttp_app.router.register_resource(asgi_resource)

# Mount startup and shutdown events from aiohttp to ASGI app
asgi_resource.lifespan_mount(aiohttp_app)

# Start the application
web.run_app(aiohttp_app)

Installation

pip install aiohttp-asgi

ASGI HTTP server

Command line tool for starting aiohttp web server with ASGI app.

Example

Create the test_app.py

from starlette.applications import Starlette
from starlette.responses import JSONResponse
from starlette.routing import Route


async def homepage(request):
    return JSONResponse({'hello': 'world'})

routes = [
    Route("/", endpoint=homepage)
]

application = Starlette(debug=True, routes=routes)

and run the test_app.py with aiohttp-asgi

aiohttp-asgi \
    --address "[::1]" \
    --port 8080 \
    test_app:application

alternatively using python -m

python -m aiohttp_asgi \
    --address "[::1]" \
    --port 8080 \
    test_app:application

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

aiohttp_asgi-0.5.0.tar.gz (11.6 kB view details)

Uploaded Source

Built Distribution

aiohttp_asgi-0.5.0-py3-none-any.whl (15.5 kB view details)

Uploaded Python 3

File details

Details for the file aiohttp_asgi-0.5.0.tar.gz.

File metadata

  • Download URL: aiohttp_asgi-0.5.0.tar.gz
  • Upload date:
  • Size: 11.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.11.0 Darwin/21.6.0

File hashes

Hashes for aiohttp_asgi-0.5.0.tar.gz
Algorithm Hash digest
SHA256 6283b69511f4e1c8c6970d1b49c6b43785818ffc86c7fe8f4bdf3802209e40c4
MD5 fee35ef1954191376d343ff828891cff
BLAKE2b-256 7936a09a46cc5a8ddeb6ef33125339d76a0302bd244ef7c24f5829ebd0edbaf7

See more details on using hashes here.

File details

Details for the file aiohttp_asgi-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: aiohttp_asgi-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 15.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.11.0 Darwin/21.6.0

File hashes

Hashes for aiohttp_asgi-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 06a0c3d3fadd7ddead8162997022e5087eb7c709f3e62b0af82d6c1bdb811945
MD5 4cc93f87b4e032617f186ebd44e44c6d
BLAKE2b-256 6635464eb0181b790a3aecacc64362f246dcd9fffbd300076416e07fa8f72fd6

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