shoe

streaming sockjs for node and the browser

  • 所有者: substack/shoe
  • 平台:
  • 許可證: Other
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

shoe

Streaming sockjs for node and the browser.

This is a more streaming,
more unixy
take on sockjs.

shoe point javascript

example

stream all the things

Browser code that takes in a stream of 0s and 1s from the server and inverts
them:

var shoe = require('shoe');
var through = require('through');

var result = document.getElementById('result');

var stream = shoe('/invert');
stream.pipe(through(function (msg) {
    result.appendChild(document.createTextNode(msg));
    this.queue(String(Number(msg)^1));
})).pipe(stream);

Server code that hosts some static files and emits 0s and 1s:

var shoe = require('shoe');
var http = require('http');

var ecstatic = require('ecstatic')(__dirname + '/static');

var server = http.createServer(ecstatic);
server.listen(9999);

var sock = shoe(function (stream) {
    var iv = setInterval(function () {
        stream.write(Math.floor(Math.random() * 2));
    }, 250);
    
    stream.on('end', function () {
        clearInterval(iv);
    });
    
    stream.pipe(process.stdout, { end : false });
});
sock.install(server, '/invert');

The server emits 0s and 1s to the browser, the browser inverts them and sends
them back, and the server dumps the binary digits to stdout.

By default, there's no logspam on stdout to clutter the output, which is a
frustrating trend in realtimey websocket libraries that violates the
rule of silence.

Just wait for a client to connect and you'll see:

$ node server.js
001011010101101000101110010000100

with dnode

Since dnode has a simple streaming api it's very simple to plug into shoe.

Just hack up some browser code:

var shoe = require('shoe');
var dnode = require('dnode');

var result = document.getElementById('result');
var stream = shoe('/dnode');

var d = dnode();
d.on('remote', function (remote) {
    remote.transform('beep', function (s) {
        result.textContent = 'beep => ' + s;
    });
});
d.pipe(stream).pipe(d);

and hack up a server piping shoe streams into dnode:

var shoe = require('shoe');
var dnode = require('dnode');

var http = require('http');
var ecstatic = require('ecstatic')(__dirname + '/static');

var server = http.createServer(ecstatic);
server.listen(9999);

var sock = shoe(function (stream) {
    var d = dnode({
        transform : function (s, cb) {
            var res = s.replace(/[aeiou]{2,}/, 'oo').toUpperCase();
            cb(res);
        }
    });
    d.pipe(stream).pipe(d);
});
sock.install(server, '/dnode');

Then open up localhost:9999 in your browser and you should see:

beep => BOOP

with express or connect

you must pass the return value of app.listen(port)

var shoe = require('shoe');

var express = require('express')
var app = express()

var sock = shoe(function (stream) { ... });

// *** must pass expcess/connect apps like this:
sock.install(app.listen(9999), '/dnode');

with reconnect

you can use reconnect just in case your sock ends or gets disconnected.

var shoe = require('shoe');
var reconnect = require('reconnect');
var es = require('event-stream');
var result = document.getElementById('result');

var r = reconnect(function (stream) {

  var s = es.mapSync(function (msg) {
      result.appendChild(document.createTextNode(msg));
      return String(Number(msg)^1);
  });
  s.pipe(stream).pipe(s);

}).connect('/invert')

browser methods

var shoe = require('shoe')

var stream = shoe(uri, cb)

Return a readable/writable stream from the sockjs path uri.
uri may be a full uri or just a path.

shoe will emit a 'connect' event when the connection is actually open,
(just like in net).
writes performed before the 'connect' event will be buffered. passing in cb to
shoe is a shortcut for shoe(uri).on('connect', cb)

server methods

var shoe = require('shoe')

All the methods from the sockjs exports objects are attached onto the shoe
function, but the shoe() function itself is special.

var sock = shoe(opts, cb)

Create a server with sockjs.createServer(opts) except this function also adds
the .install() function below.

If cb is specified, it fires cb(stream) on 'connection' events.

sock.install(server, opts)

Call sock.installHandler() with the default option of spamming stdout with log
messages switched off in place of just emitting 'log' messages
on the sock object instead. This is a much less spammy default that gets out
of your way.

If opts is a string, use it as the opts.prefix.

server events

All the messages that sockjs normally emits will be available on the sock
object plus the events below:

sock.on('log', function (severity, msg) { ... })

Using the default logger with sock.install() will cause these 'log' messages
to be emitted instead of spamming stdout.

install

With npm do:

npm install shoe

license

MIT

主要指標

概覽
名稱與所有者substack/shoe
主編程語言JavaScript
編程語言JavaScript (語言數: 1)
平台
許可證Other
所有者活动
創建於2012-06-23 02:44:20
推送於2021-05-20 09:38:17
最后一次提交2013-08-28 17:14:49
發布數15
最新版本名稱0.0.15 (發布於 2013-08-28 17:14:49)
第一版名稱0.0.1 (發布於 2012-06-25 00:26:42)
用户参与
星數431
關注者數17
派生數46
提交數42
已啟用問題?
問題數20
打開的問題數14
拉請求數7
打開的拉請求數8
關閉的拉請求數4
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?