]> git.sesse.net Git - remoteglot/blobdiff - www/serve-analysis.js
Fix a typo.
[remoteglot] / www / serve-analysis.js
index 5778dc921c99ced8bb8c82a64250f9e4d513ca5e..fcb91fa83974ee51deef8f538e4666aed228ec2d 100644 (file)
@@ -56,7 +56,7 @@ var reread_file = function(event, filename) {
 var possibly_wakeup_clients = function() {
        for (var i in sleeping_clients) {
                clearTimeout(sleeping_clients[i].timer);
-               mark_recently_seen(sleeping_clients[request_id].unique);
+               mark_recently_seen(sleeping_clients[i].unique);
                send_json(sleeping_clients[i].response, sleeping_clients[i].accept_gzip);
        }
        sleeping_clients = {};
@@ -128,7 +128,8 @@ var count_viewers = function() {
 fs.watch(path.dirname(json_filename), reread_file);
 reread_file(null, path.basename(json_filename));
 
-http.createServer(function(request, response) {
+var server = http.createServer();
+server.on('request', function(request, response) {
        var u = url.parse(request.url, true);
        var ims = (u.query)['ims'];
        var unique = (u.query)['unique'];
@@ -168,4 +169,16 @@ http.createServer(function(request, response) {
        client.accept_gzip = accept_gzip;
        client.unique = unique;
        sleeping_clients[request_id++] = client;
-}).listen(5000);
+
+       request.socket.client = client;
+});
+server.on('connection', function(socket) {
+       socket.on('close', function() {
+               var client = socket.client;
+               if (client) {
+                       mark_recently_seen(client.unique);
+                       delete sleeping_clients[client.request_id];
+               }
+       });
+});
+server.listen(5000);