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
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.
|