ASGI specs, helper code, and adapters
Project description
ASGI is a standard for Python asynchronous web apps and servers to communicate with each other, and positioned as an asynchronous successor to WSGI. You can read more at https://asgi.readthedocs.io/en/latest/
This package includes ASGI base libraries, such as:
Sync-to-async and async-to-sync function wrappers, asgiref.sync
Server base classes, asgiref.server
A WSGI-to-ASGI adapter, in asgiref.wsgi
Function wrappers
These allow you to wrap or decorate async or sync functions to call them from the other style (so you can call async functions from a synchronous thread, or vice-versa).
In particular:
AsyncToSync lets a synchronous subthread stop and wait while the async function is called on the main thread’s event loop, and then control is returned to the thread when the async function is finished.
SyncToAsync lets async code call a synchronous function, which is run in a threadpool and control returned to the async coroutine when the synchronous function completes.
The idea is to make it easier to call synchronous APIs from async code and asynchronous APIs from synchronous code so it’s easier to transition code from one style to the other. In the case of Channels, we wrap the (synchronous) Django view system with SyncToAsync to allow it to run inside the (asynchronous) ASGI server.
Threadlocal replacement
This is a drop-in replacement for threading.local that works with both threads and asyncio Tasks. Even better, it will proxy values through from a task-local context to a thread-local context when you use sync_to_async to run things in a threadpool, and vice-versa for async_to_sync.
If you instead want true thread- and task-safety, you can set thread_critical on the Local object to ensure this instead.
Server base classes
Includes a StatelessServer class which provides all the hard work of writing a stateless server (as in, does not handle direct incoming sockets but instead consumes external streams or sockets to work out what is happening).
An example of such a server would be a chatbot server that connects out to a central chat server and provides a “connection scope” per user chatting to it. There’s only one actual connection, but the server has to separate things into several scopes for easier writing of the code.
You can see an example of this being used in frequensgi.
WSGI-to-ASGI adapter
Allows you to wrap a WSGI application so it appears as a valid ASGI application.
Simply wrap it around your WSGI application like so:
asgi_application = WsgiToAsgi(wsgi_application)
The WSGI application will be run in a synchronous threadpool, and the wrapped ASGI application will be one that accepts http class messages.
Please note that not all extended features of WSGI may be supported (such as file handles for incoming POST bodies).
Dependencies
asgiref requires Python 3.5 or higher.
Contributing
Please refer to the main Channels contributing docs.
Testing
To run tests, make sure you have installed the tests extra with the package:
cd asgiref/ pip install -e .[tests] pytest
Building the documentation
The documentation uses Sphinx:
cd asgiref/docs/ pip install sphinx
To build the docs, you can use the default tools:
sphinx-build -b html . _build/html # or `make html`, if you've got make set up cd _build/html python -m http.server
…or you can use sphinx-autobuild to run a server and rebuild/reload your documentation changes automatically:
pip install sphinx-autobuild sphinx-autobuild . _build/html
Maintenance and Security
To report security issues, please contact security@djangoproject.com. For GPG signatures and more security process information, see https://docs.djangoproject.com/en/dev/internals/security/.
To report bugs or request new features, please open a new GitHub issue.
This repository is part of the Channels project. For the shepherd and maintenance team, please see the main Channels readme.
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
Built Distribution
File details
Details for the file asgiref-3.1.3.tar.gz
.
File metadata
- Download URL: asgiref-3.1.3.tar.gz
- Upload date:
- Size: 13.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.4.3 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.6.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 566126b4cbf190c315121965253ecb2159499197ff4afd686e0921f4dd987999 |
|
MD5 | 00ab05aeb739ebc676d3e788b9adddeb |
|
BLAKE2b-256 | a26cae3f69d30aad753f8ade8925f8c9f30f2dce5dfe3b44e8b7db414bf4a2ea |
File details
Details for the file asgiref-3.1.3-py2.py3-none-any.whl
.
File metadata
- Download URL: asgiref-3.1.3-py2.py3-none-any.whl
- Upload date:
- Size: 15.1 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.4.3 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.6.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 34227987327d13bc4b19d338faa6fed8a25cea79cca2e9e50490d212f56470f8 |
|
MD5 | 191c48da47674b5dd2a2b9a14af056d1 |
|
BLAKE2b-256 | c2c4db607d2dcdd1d88763528de1066dec9f36cca470c1d101de5cc35c90b0b9 |