Simple websocket server and client with callback-based API.
Project description
simple-websockets
Simple websocket server and client with callback-based API.
Table of Contents
Installation
pip install simple-websockets
Usage
Server
Here is a example of websocket echo server:
from simplews import SimpleWSServer
server = SimpleWSServer(host="",
port=8765,
print_details=True, # Print basic logs
print_messages=True) # Print every message received
@server.on_connect
async def on_connect(ws): # called when a client connects
print(f'Client {ws.remote_address} connected')
@server.on_message
async def on_message(ws, message): # called when a message is received from a client
await ws.send(message) # send the message back to the client
@server.on_close
async def on_close(ws): # called when a client disconnects
print(f'Client {ws.remote_address} disconnected')
server.serve() # serve forever
Client
Here is a example of websocket client:
from simplews import SimpleWSClient
client = SimpleWSClient(uri="ws://localhost:8765",
print_details=True, # Print basic logs
print_messages=True) # Print every message received
@client.on_connect
async def on_connect(ws): # called when the connection is established
print(f'Connected to {ws.remote_address}')
@client.on_message
async def on_message(ws, message): # called when a message is received
print(f'Received: {message}')
@client.on_close
async def on_close(ws): # called when the connection is closed
print(f'Connection to {ws.remote_address} closed')
client.connect() # connect to the server
Tips
- All callbacks are asynchronous, so don't forget
async
. - ws.send() is a coroutine, so don't forget
await
. - For more information about the
ws
argument, see WebSocketServerProtocol for server and WebSocketClientProtocol for client. - server.broadcast() is the preferred way to send a message to all connected clients, and it's not a coroutine, so no
await
is needed.
License
simple-websockets
is distributed under the terms of the GPL-3.0-only license.
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
simple_websockets-0.1.0.tar.gz
(14.9 kB
view details)
Built Distribution
File details
Details for the file simple_websockets-0.1.0.tar.gz
.
File metadata
- Download URL: simple_websockets-0.1.0.tar.gz
- Upload date:
- Size: 14.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6741ee97fb0923049b2f44d98ed5c4681e4e3245551ee27ca13e14b71f5b57a9 |
|
MD5 | 9678b48c3c335a83fc7cd358bb0bdbbb |
|
BLAKE2b-256 | c68a0a22719a88080dde4576a6ec4eb4a5944775192126ef37e8626479dd1ad0 |
File details
Details for the file simple_websockets-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: simple_websockets-0.1.0-py3-none-any.whl
- Upload date:
- Size: 16.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0942694373aed469470dc0e2f73971276617cfb9c5c790aa1c15328b76924943 |
|
MD5 | e77b432d34c4ca95a62c7d67f3aeb743 |
|
BLAKE2b-256 | 72ae13c83fd35b27d7a2e41212df25ff96f2d7d3070472a593694f2461d4cae0 |