From a976cc54391d50265332016f34a224a267db7eb2 Mon Sep 17 00:00:00 2001 From: Sebastien Windal Date: Sat, 30 Mar 2013 22:21:20 -0400 Subject: [PATCH] configurable server poll timeout --- JScribbleServer.js | 30 +++++++++++++++++++++--------- app.js | 2 +- 2 files changed, 22 insertions(+), 10 deletions(-) diff --git a/JScribbleServer.js b/JScribbleServer.js index a908214..b253098 100644 --- a/JScribbleServer.js +++ b/JScribbleServer.js @@ -1,9 +1,13 @@ var _ = require('underscore'); - +var socket = null; +var io; module.exports = { - start: function(port) { - var io = require('socket.io').listen(port); + + start: function(port, timeout) { + io = require('socket.io').listen(port); + io.set('close timeout', timeout); + io.set('client store expiration', timeout); var messages = []; @@ -15,8 +19,8 @@ module.exports = { io.set("polling duration", 10); }); - io.sockets.on('connection', function (socket) { // handler for incoming connections - + io.sockets.on('connection', function (sock) { // handler for incoming connections + socket = sock; socket.on('chat', function (data) { var msg = JSON.parse(data); msg.time = new Date(); @@ -62,11 +66,19 @@ module.exports = { }); socket.on('close', function(data) { - var msg= JSON.parse(data); + var msg = JSON.parse(data); socket.disconnect(); }); - }); - } - }; + }); + }, + stop: function() { + console.log("stoping server"); + if (socket) { + socket.disconnect(); + io.server.close(); + } + socket = null; + } +}; diff --git a/app.js b/app.js index 277a817..ef35d36 100644 --- a/app.js +++ b/app.js @@ -33,5 +33,5 @@ app.listen(port, function() { app.get('/', routes.index); var server = require('./JScribbleServer'); -server.start(app); +server.start(app, 5);