socketio-transport

socketio-transport will allow you to define request handlers on the server side and to access them from the client side.

#Socketio-transport

socketio-transport will allow you to define request handlers (file, DB, ...) on the server side and to access them from the client side.

#Installation

npm install socketio-transport

#How to use

socketio-transport has a client-side and a server-side part, just like socket.io which it's based upon. It'll just wrap socket.io to provide a nice abstraction to make requests and open channels from the client side.

Require the server part of socketio-transport:

var transport = require("socketio-transport").Server;

And define you request handlers:

var handlers = {
    /**
     * payload is a JSON sent by the client
     * onData is the callback that will receive each update
     * onEnd will be called with the last update
     */
    testfunction (payloadonEndonData) {
        setInterval(function () {
            onData((new Date));
        }, 200);
    }
}

Then register the socket.io that you want to use and add the handlers too. The handlers need to be wrapped in an observable-store, because they can be shared between several transports and they will know when handlers are added/removed/updated if needed.

// the socket.io 
var io = require("socket.io").listen(8000);
 
// The observable-store to wrap the handlers 
var Store = require("observable-store");
 
// register socket.io and the handlers: 
socketioTransport(io, new Store(handlers));

Require the client part of socketio-transport

var SocketioTransport = require("socketio-transport").Client;

Initialize it with the socket.io that you want to use:

var transport = new SocketioTransport(io.connect("http://localhost:8000"));

And you're now free to query your request handlers:

transport.listen("test", { ...}, function onData(data) {
    // do something with data 
    console.log(data); // Date, triggered every 200ms 
});

LICENSE

MIT