diff options
author | Hakim El Hattab | 2013-03-08 18:49:28 -0500 |
---|---|---|
committer | Hakim El Hattab | 2013-03-08 18:49:28 -0500 |
commit | 2bd5e8b65b5e015c7c7ceffeff845e41811007ed (patch) | |
tree | 93cd402c11465003c2b669f0ac2a8162337e649f /plugin/multiplex/index.js | |
parent | 16f9749db5f1e3294b574fd0acddf52280c4bb1d (diff) | |
parent | 4963f15ab31406cf1ee53dc4d116eb8f630f2b1a (diff) |
merge in multiplex (#98)
Diffstat (limited to 'plugin/multiplex/index.js')
-rw-r--r-- | plugin/multiplex/index.js | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/plugin/multiplex/index.js b/plugin/multiplex/index.js new file mode 100644 index 0000000..bf22cb1 --- /dev/null +++ b/plugin/multiplex/index.js @@ -0,0 +1,48 @@ +var express = require('express'); +var fs = require('fs'); +var io = require('socket.io'); +var crypto = require('crypto'); + +var app = express.createServer(); +var staticDir = express.static; + +io = io.listen(app); + +var opts = { + port: 1948, + baseDir : __dirname + '/../../' +}; + +io.sockets.on('connection', function(socket) { + socket.on('slidechanged', function(slideData) { + if (createHash(slideData.secret) === slideData.socketId) { + slideData.secret = null; + socket.broadcast.emit(slideData.socketId, slideData); + }; + }); +}); + +app.configure(function() { + [ 'css', 'js', 'plugin', 'lib' ].forEach(function(dir) { + app.use('/' + dir, staticDir(opts.baseDir + dir)); + }); +}); + +app.get("/", function(req, res) { + fs.createReadStream(opts.baseDir + '/index.html').pipe(res); +}); + +app.get("/token", function(req,res) { + var ts = new Date().getTime(); + var rand = Math.floor(Math.random()*9999999); + var secret = ts.toString() + rand.toString(); + res.send({secret: secret, socketId: createHash(secret)}); +}); + +var createHash = function(secret) { + var cipher = crypto.createCipher('blowfish', secret); + return(cipher.final('hex')); +}; + +// Actually listen +app.listen(opts.port || null); |