summaryrefslogtreecommitdiffhomepage
path: root/plugin/multiplex/index.js
diff options
context:
space:
mode:
authorHakim El Hattab2013-03-08 18:49:28 -0500
committerHakim El Hattab2013-03-08 18:49:28 -0500
commit2bd5e8b65b5e015c7c7ceffeff845e41811007ed (patch)
tree93cd402c11465003c2b669f0ac2a8162337e649f /plugin/multiplex/index.js
parent16f9749db5f1e3294b574fd0acddf52280c4bb1d (diff)
parent4963f15ab31406cf1ee53dc4d116eb8f630f2b1a (diff)
merge in multiplex (#98)
Diffstat (limited to 'plugin/multiplex/index.js')
-rw-r--r--plugin/multiplex/index.js48
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);