msgpack rpc over websockets
Project description
websocket-rpc
msgpack rpc over websocket
Examples
server:
import asyncio
from sanic import Sanic
from wsrpc import WebsocketRPC
app = Sanic(__name__)
class SampleHandler:
def __init__(self, rpc):
self.remote = rpc
async def add(self, a, b):
await asyncio.sleep(5)
return a + b
async def test(self):
return 23
@app.websocket('/')
async def home(request, ws):
await WebsocketRPC(ws, SampleHandler).run()
app.run(host="0.0.0.0", port=5555, debug=False)
client:
import asyncio
import websockets
from wsrpc import WebsocketRPC
loop = asyncio.get_event_loop()
async def go():
async with websockets.connect('ws://127.0.0.1:5555/') as ws:
rpc = WebsocketRPC(ws=ws, client_mode=True)
jobs = [rpc.request.add(a, b) for a, b in zip(range(10), range(5, 15))]
r = await asyncio.gather(*jobs)
print(r)
r = await rpc.notify.add(2, 3)
print(r)
loop.run_until_complete(go())
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
websocket-rpc-0.0.4.tar.gz
(6.9 kB
view hashes)
Built Distribution
Close
Hashes for websocket_rpc-0.0.4-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6185356fef83e2fe3d39fff24618b77afd9b80790fe23697b8ff8f156b0c0e6e |
|
MD5 | 2bf4f0511e569f7975f4bb088f433075 |
|
BLAKE2b-256 | a54c9c16dfd30555bb4444df94f9916e07d8ce371211c036d4d610c30f8c244f |