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
)

# [Optional]
asgi_resource.lifespan_mount(
    aiohttp_app,
    startup=True,
    # By default starlette didn't
    # handle "lifespan.shutdown"
    shutdown=False,
)

# 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.4.3.tar.gz (11.5 kB view details)

Uploaded Source

Built Distribution

aiohttp_asgi-0.4.3-py3-none-any.whl (15.8 kB view details)

Uploaded Python 3

File details

Details for the file aiohttp-asgi-0.4.3.tar.gz.

File metadata

  • Download URL: aiohttp-asgi-0.4.3.tar.gz
  • Upload date:
  • Size: 11.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.3 readme-renderer/32.0 requests/2.28.1 requests-toolbelt/0.9.1 urllib3/1.26.12 tqdm/4.62.3 importlib-metadata/4.11.0 keyring/21.8.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.10.2

File hashes

Hashes for aiohttp-asgi-0.4.3.tar.gz
Algorithm Hash digest
SHA256 2b211ed97ad174bdfcf2419465386e2af83ad4cf25bb06a463ad49e8e038e185
MD5 d0c0059063c141491af88f4045ea0387
BLAKE2b-256 6213800b9a6ee48e475b156c70d48ec83d955b14c786cc803eaf7a846629178a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: aiohttp_asgi-0.4.3-py3-none-any.whl
  • Upload date:
  • Size: 15.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.3 readme-renderer/32.0 requests/2.28.1 requests-toolbelt/0.9.1 urllib3/1.26.12 tqdm/4.62.3 importlib-metadata/4.11.0 keyring/21.8.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.10.2

File hashes

Hashes for aiohttp_asgi-0.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 1a77540f4758a6c8736797abd553e80e29a8cade6c864808d483e98e35a78724
MD5 e06524966f549a397b3b03ac67037c2b
BLAKE2b-256 a92994c760ca9a5258b958da3984a06a0306ecc347ac577d144f139af4204ef8

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