You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
178 lines
5.5 KiB
178 lines
5.5 KiB
11 months ago
|
Metadata-Version: 2.1
|
||
|
Name: wsproto
|
||
|
Version: 1.2.0
|
||
|
Summary: WebSockets state-machine based protocol implementation
|
||
|
Home-page: https://github.com/python-hyper/wsproto/
|
||
|
Author: Benno Rice
|
||
|
Author-email: benno@jeamland.net
|
||
|
License: MIT License
|
||
|
Classifier: Development Status :: 5 - Production/Stable
|
||
|
Classifier: Intended Audience :: Developers
|
||
|
Classifier: License :: OSI Approved :: MIT License
|
||
|
Classifier: Programming Language :: Python
|
||
|
Classifier: Programming Language :: Python :: 3
|
||
|
Classifier: Programming Language :: Python :: 3.7
|
||
|
Classifier: Programming Language :: Python :: 3.8
|
||
|
Classifier: Programming Language :: Python :: 3.9
|
||
|
Classifier: Programming Language :: Python :: 3.10
|
||
|
Classifier: Programming Language :: Python :: Implementation :: CPython
|
||
|
Classifier: Programming Language :: Python :: Implementation :: PyPy
|
||
|
Requires-Python: >=3.7.0
|
||
|
Description-Content-Type: text/x-rst
|
||
|
License-File: LICENSE
|
||
|
Requires-Dist: h11 <1,>=0.9.0
|
||
|
|
||
|
========================================================
|
||
|
Pure Python, pure state-machine WebSocket implementation
|
||
|
========================================================
|
||
|
|
||
|
.. image:: https://github.com/python-hyper/wsproto/workflows/CI/badge.svg
|
||
|
:target: https://github.com/python-hyper/wsproto/actions
|
||
|
:alt: Build Status
|
||
|
.. image:: https://codecov.io/gh/python-hyper/wsproto/branch/main/graph/badge.svg
|
||
|
:target: https://codecov.io/gh/python-hyper/wsproto
|
||
|
:alt: Code Coverage
|
||
|
.. image:: https://readthedocs.org/projects/wsproto/badge/?version=latest
|
||
|
:target: https://wsproto.readthedocs.io/en/latest/
|
||
|
:alt: Documentation Status
|
||
|
.. image:: https://img.shields.io/badge/chat-join_now-brightgreen.svg
|
||
|
:target: https://gitter.im/python-hyper/community
|
||
|
:alt: Chat community
|
||
|
|
||
|
|
||
|
This repository contains a pure-Python implementation of a WebSocket protocol
|
||
|
stack. It's written from the ground up to be embeddable in whatever program you
|
||
|
choose to use, ensuring that you can communicate via WebSockets, as defined in
|
||
|
`RFC6455 <https://tools.ietf.org/html/rfc6455>`_, regardless of your programming
|
||
|
paradigm.
|
||
|
|
||
|
This repository does not provide a parsing layer, a network layer, or any rules
|
||
|
about concurrency. Instead, it's a purely in-memory solution, defined in terms
|
||
|
of data actions and WebSocket frames. RFC6455 and Compression Extensions for
|
||
|
WebSocket via `RFC7692 <https://tools.ietf.org/html/rfc7692>`_ are fully
|
||
|
supported.
|
||
|
|
||
|
wsproto supports Python 3.6.1 or higher.
|
||
|
|
||
|
To install it, just run:
|
||
|
|
||
|
.. code-block:: console
|
||
|
|
||
|
$ pip install wsproto
|
||
|
|
||
|
|
||
|
Usage
|
||
|
=====
|
||
|
|
||
|
Let's assume you have some form of network socket available. wsproto client
|
||
|
connections automatically generate a HTTP request to initiate the WebSocket
|
||
|
handshake. To create a WebSocket client connection:
|
||
|
|
||
|
.. code-block:: python
|
||
|
|
||
|
from wsproto import WSConnection, ConnectionType
|
||
|
from wsproto.events import Request
|
||
|
|
||
|
ws = WSConnection(ConnectionType.CLIENT)
|
||
|
ws.send(Request(host='echo.websocket.org', target='/'))
|
||
|
|
||
|
To create a WebSocket server connection:
|
||
|
|
||
|
.. code-block:: python
|
||
|
|
||
|
from wsproto.connection import WSConnection, ConnectionType
|
||
|
|
||
|
ws = WSConnection(ConnectionType.SERVER)
|
||
|
|
||
|
Every time you send a message, or call a ping, or simply if you receive incoming
|
||
|
data, wsproto might respond with some outgoing data that you have to send:
|
||
|
|
||
|
.. code-block:: python
|
||
|
|
||
|
some_socket.send(ws.bytes_to_send())
|
||
|
|
||
|
Both connection types need to receive incoming data:
|
||
|
|
||
|
.. code-block:: python
|
||
|
|
||
|
ws.receive_data(some_byte_string_of_data)
|
||
|
|
||
|
And wsproto will issue events if the data contains any WebSocket messages or state changes:
|
||
|
|
||
|
.. code-block:: python
|
||
|
|
||
|
for event in ws.events():
|
||
|
if isinstance(event, Request):
|
||
|
# only client connections get this event
|
||
|
ws.send(AcceptConnection())
|
||
|
elif isinstance(event, CloseConnection):
|
||
|
# guess nobody wants to talk to us any more...
|
||
|
elif isinstance(event, TextMessage):
|
||
|
print('We got text!', event.data)
|
||
|
elif isinstance(event, BytesMessage):
|
||
|
print('We got bytes!', event.data)
|
||
|
|
||
|
Take a look at our docs for a `full list of events
|
||
|
<https://wsproto.readthedocs.io/en/latest/api.html#events>`!
|
||
|
|
||
|
Testing
|
||
|
=======
|
||
|
|
||
|
It passes the autobahn test suite completely and strictly in both client and
|
||
|
server modes and using permessage-deflate.
|
||
|
|
||
|
If you want to run the compliance tests, go into the compliance directory and
|
||
|
then to test client mode, in one shell run the Autobahn test server:
|
||
|
|
||
|
.. code-block:: console
|
||
|
|
||
|
$ wstest -m fuzzingserver -s ws-fuzzingserver.json
|
||
|
|
||
|
And in another shell run the test client:
|
||
|
|
||
|
.. code-block:: console
|
||
|
|
||
|
$ python test_client.py
|
||
|
|
||
|
And to test server mode, run the test server:
|
||
|
|
||
|
.. code-block:: console
|
||
|
|
||
|
$ python test_server.py
|
||
|
|
||
|
And in another shell run the Autobahn test client:
|
||
|
|
||
|
.. code-block:: console
|
||
|
|
||
|
$ wstest -m fuzzingclient -s ws-fuzzingclient.json
|
||
|
|
||
|
|
||
|
Documentation
|
||
|
=============
|
||
|
|
||
|
Documentation is available at https://wsproto.readthedocs.io/en/latest/.
|
||
|
|
||
|
Contributing
|
||
|
============
|
||
|
|
||
|
``wsproto`` welcomes contributions from anyone! Unlike many other projects we
|
||
|
are happy to accept cosmetic contributions and small contributions, in addition
|
||
|
to large feature requests and changes.
|
||
|
|
||
|
Before you contribute (either by opening an issue or filing a pull request),
|
||
|
please `read the contribution guidelines`_.
|
||
|
|
||
|
.. _read the contribution guidelines: http://python-hyper.org/en/latest/contributing.html
|
||
|
|
||
|
License
|
||
|
=======
|
||
|
|
||
|
``wsproto`` is made available under the MIT License. For more details, see the
|
||
|
``LICENSE`` file in the repository.
|
||
|
|
||
|
Authors
|
||
|
=======
|
||
|
|
||
|
``wsproto`` was created by @jeamland, and is maintained by the python-hyper
|
||
|
community.
|