Skip to main content

WSRPC is the RPC over WebSocket for aiohttp

Project description

Travis CI Latest Version https://img.shields.io/pypi/wheel/wsrpc-aiohttp.svg https://img.shields.io/pypi/pyversions/wsrpc-aiohttp.svg https://img.shields.io/pypi/l/wsrpc-aiohttp.svg

Remote Procedure call through WebSocket between browser and tornado.

Features

  • Initiating call client function from server side.

  • Calling the server method from the client.

  • Transferring any exceptions from a client side to the server side and vise versa.

  • The frontend-library are well done for usage without any modification.

  • Fully asynchronous server-side functions.

  • Thread-based websocket handler for writing fully-synchronous code (for synchronous database drivers etc.)

  • Protected server-side methods (starts with underline never will be call from clients-side directly)

  • Asynchronous connection protocol. Server or client can call multiple methods with unpredictable ordering of answers.

  • If ujson is installed messages will be serialize/deserialize with it.

Installation

Install via pip:

pip install wsrpc-aiohttp

Install ujson if you want:

pip install ujson

Simple usage

Add the backend side

from time import time
## If you want write async tornado code import it
# from from wsrpc import WebSocketRoute, WebSocket, wsrpc_static
## else you should use thread-base handler
from wsrpc import WebSocketRoute, WebSocketThreaded as WebSocket, wsrpc_static

tornado.web.Application((
    # js static files will available as "/js/wsrpc.min.js".
    wsrpc_static(r'/js/(.*)'),
    # WebSocket handler. Client will connect here.
    (r"/ws/", WebSocket),
    # Serve other static files
    (r'/(.*)', tornado.web.StaticFileHandler, {
         'path': os.path.join(project_root, 'static'),
         'default_filename': 'index.html'
    }),
))

# This class should be call by client.
# Connection object will be have the instance of this class when will call route-alias.
class TestRoute(WebSocketRoute):
    # This method will be executed when client will call route-alias first time.
    def init(self, **kwargs):
        # the python __init__ must be return "self". This method might return anything.
        return kwargs

    def getEpoch(self):
        # this method named by camelCase because the client can call it.
        return time()

# stateful request
# this is the route alias TestRoute as "test1"
WebSocket.ROUTES['test1'] = TestRoute

# stateless request
WebSocket.ROUTES['test2'] = lambda *a, **kw: True

# initialize ThreadPool. Needed when using WebSocketThreaded.
WebSocket.init_pool()

Add the frontend side

<script type="text/javascript" src="/js/q.min.js"></script>
<script type="text/javascript" src="/js/wsrpc.min.js"></script>
<script>
    var url = ((window.location.protocol==="https):"?"wss://":"ws://") + window.location.host + '/ws/';
    RPC = WSRPC(url, 5000);
    RPC.addRoute('test', function (data) { return "Test called"; });
    RPC.connect();

    RPC.call('test1.getEpoch').then(function (data) {
        console.log(data);
    }, function (error) {
        alert(error);
    }).done();

    RPC.call('test2').then(function (data) { console.log(data); }).done();
</script>

Reverse call from Server to Client

backend:

def do_notify(self):
    awesome = 'Notification for you!'
    yield self.socket.call('notify', result=awesome)

frontend:

<script>
    var url = (window.location.protocol==="https:"?"wss://":"ws://") + window.location.host + '/ws/';
    RPC = WSRPC(url, 5000);
    RPC.addRoute('notify', function (data) { return data.result; });
    RPC.connect();
</script>

Documentation

All available documentation here.

Example

Example running there demo.

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

wsrpc-aiohttp-1.0.2.tar.gz (55.3 kB view details)

Uploaded Source

Built Distribution

wsrpc_aiohttp-1.0.2-py3-none-any.whl (57.7 kB view details)

Uploaded Python 3

File details

Details for the file wsrpc-aiohttp-1.0.2.tar.gz.

File metadata

  • Download URL: wsrpc-aiohttp-1.0.2.tar.gz
  • Upload date:
  • Size: 55.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.18.4 setuptools/33.1.1 requests-toolbelt/0.8.0 tqdm/4.20.0 CPython/3.6.5

File hashes

Hashes for wsrpc-aiohttp-1.0.2.tar.gz
Algorithm Hash digest
SHA256 ff4a676c2afea127ba0238889525f468172bdbbfd3b81d2c1eee066554e529f8
MD5 cdf0655c0c87e055572c1a3495bb35aa
BLAKE2b-256 c1718360792731fc38a5c45035a3a80ce5dfc7762e9f3cc3fb0e72ed83f2b558

See more details on using hashes here.

File details

Details for the file wsrpc_aiohttp-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: wsrpc_aiohttp-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 57.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.18.4 setuptools/33.1.1 requests-toolbelt/0.8.0 tqdm/4.20.0 CPython/3.6.5

File hashes

Hashes for wsrpc_aiohttp-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7248ef74c3d9bed87aa9729c750fa7cf5cfce2267169bc44e2163db70cdaf310
MD5 0d55fdf2130fedad9f6d3975e7cf9e1e
BLAKE2b-256 7c9fd02fefa4260c8795a625c0ceb074ef32d37a460a65db00063f525d56d6c8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page