A lightweight, multithreaded WebSocket server written in Python.
To demonstrate one use case for WebSock, an online chat application has been set up here. The application's backend server is built on top of WebSock and is deployed within a Docker container hosted by Digital Ocean. The code for the chat application is provided within the examples directory.
WebSock is a Python implementation of a WebSocket server. WebSock allows you to create real-time applications, such as chatrooms or stock dashboards, without having to implement all the low-level details specified in the WebSocket protocol. The server application is built using the TCP socket module provided by the Python programming language and follows the latest version of the WebSocket protocol specification (RFC 6455). The project was motivated by our desire to learn more about how data is transferred across networks while providing a useful tool for others to build on top of.
WebSock is an abstraction that hides the unnecessary complexities of the WebSocket protocol and provides a simple API that allows users to get their applications up and running quickly. The server listens for new client connections on its main application thread while offloading the management of individual client interactions to a dedicated client thread -- creating a new thread for each client connection. Client threads are created the moment an upgrade request is received and are destroyed following the transmission of the final close frame. This design allows the server to manage multiple clients concurrently without the concern of a non-responding client blocking the transmission of data to/from other clients.
Install the library by executing:
pip install websock
WebSock's API is easy to integrate into any application. To use the server you must provide an implementation for any or all of the following methods:
def on_data_receive(client, data):
'''Called by the WebSocket server when data is received.'''
# Your implementation here.
def on_connection_open(client):
'''Called by the WebSocket server when a new connection is opened.'''
# Your implementation here.
def on_error(exception):
'''Called by the WebSocket server whenever an Exception is thrown.'''
# Your implementation here.
def on_connection_close(client):
'''Called by the WebSocket server when a connection is closed.'''
# Your implementation here.
def on_server_destruct():
'''Called immediately prior to the WebSocket server shutting down.'''
# Your implementation here.
Then, simply import and instantiate a new WebSocketServer object. The server expects a host and port, as well as any combination of the above methods.
from websock import WebSocketServer
my_server = WebSocketServer(
"127.0.0.1", # Example host.
8467, # Example port.
on_data_receive = on_data_receive,
on_connection_open = on_connection_open,
on_error = on_error,
on_connection_close = on_connection_close,
on_server_destruct = on_server_destruct
)
my_server.serve_forever()
For more guidance, check out the code for the example chat application built using WebSock in the examples directory.
There you will also find the flutter example.
You can check out the full documentation for the API here.
- Kai Bailey - Software engineering student at the University of Alberta.
- Fraser Bulbuc - Software engineering student at the University of Alberta.
- The latest official WebSocket protocol specification, RFC 6455.
- Mozilla has an abundance of information on web technologies including a section on WebSockets.
- A chat bot, built using ChatterBot, was added to the example chat application so that the chat room is never empty!
- Fix all errors from the autobahn-tests.