Adapter to running ASGI applications on aiohttp
Project description
aiohttp-asgi
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
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
aiohttp-asgi-0.3.0.tar.gz
(6.8 kB
view details)
Built Distribution
File details
Details for the file aiohttp-asgi-0.3.0.tar.gz
.
File metadata
- Download URL: aiohttp-asgi-0.3.0.tar.gz
- Upload date:
- Size: 6.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1f1f2cc71e3b0d283c24ae23bf0d7a6b72b0573b41b87f5df6f5774fc0c9de2a |
|
MD5 | 1e6244d4c3bef1573d82987fc905e68f |
|
BLAKE2b-256 | ca1fbc064824a9b9139b3c6cfecc7aa2075a0caace55a39074f1b17d8704f8be |
File details
Details for the file aiohttp_asgi-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: aiohttp_asgi-0.3.0-py3-none-any.whl
- Upload date:
- Size: 15.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 46e797d79fe839ea5a6b6c414e9e351fb59659351965f2b276c546b16df92163 |
|
MD5 | 25c9b91f991db21e21ae7a656020aced |
|
BLAKE2b-256 | 55011abe3546916b03b18eae358529d97a51bbd0517ff3eca59a198707cd7bfe |