/RRM

tiny request-response-manager for bi-directional transports

Primary LanguageJavaScript

RRM

RRM (Request-Response-Manager) is a tiny tool to facilitate request & response on bi-directional transports, such as websockets, webworkers or webrtc.

Uses promises for async flow.

Features

  • completly transport-agnostic
  • supports messages without need for response ("events")
  • wildcards as fallback or default handler
  • timeouts

Env-Requirements

  • Promises
  • Browserify for usage in browser
  • Maps

Usage

Setup example with Webworker

var hostWorker = new Worker("worker.js");

//setup RRM by telling him where to send messages
var requestManager = new RequestManager(function(data){
    hostWorker.postMessage(JSON.stringify(data));
});

//send all incoming from worker directly to RRM
hostWorker.onmessage = function(e) {
    requestManager.handleRequest(JSON.parse(e.data));
};

//add handlers for incoming messages and events
requestManager.setHandler("myActionType",function(data){
    //if the type identifies it as an event, we must return a promise
    return new Promise(function(resolve,reject){
        //...
    });
});

The worker side is set up in the same way.

Requests and Events

//send a request of type "someAction" with a timeout of 1sec
requestManager.createRequest("someAction",data,1000);

//emit an event - means we don't expect a response
requestManager.emitEvent("myEvent",data);
  • If no handler is set for the action on the other side, the response is an error
  • If the timeout is not met, the response is an error

Wildcards

//can set a default or fallback handler (used if no other handler matches)
requestManager.setHandler("*",function(data,action){
    switch(action){
        //...
    }
});