This repository was archived by the owner on Aug 4, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdaemon.js
More file actions
73 lines (66 loc) · 1.73 KB
/
daemon.js
File metadata and controls
73 lines (66 loc) · 1.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
'use strict'
var mongoose = require('mongoose');
var q = require('q');
mongoose.Promise = require('q').Promise;
var schemas = require('./schemas');
mongoose.connect('localhost', 'cardsagainstcontinuity', function() {
console.log("Daemon running.");
setTimeout(function() {
removeIdlePlayers()
.then(removeEmptyGames);
}, 60000)
});
function removeEmptyGames() {
var deferred = q.defer();
schemas.Game.find({})
.cursor({batchSize: 100})
.eachAsync(function(Game) {
return checkEmptyGame(Game._id);
}, function() {
});
return deferred.promise;
}
function checkEmptyGame(id) {
var deferred = q.defer();
schemas.Player.find({_game: id}).count(function(err, Count) {
if (err) {
deferred.reject(err);
} else {
if (Count === 0) {
console.log("Removing game " + id);
schemas.Game.remove({_id: id})
.exec(function(err) {
if (err)
deferred.reject(err);
else
deferred.resolve();
});
} else {
deferred.resolve();
}
}
});
return deferred.promise;
}
function removeIdlePlayers() {
var deferred = q.defer();
var toRemove = [];
schemas.Player.find({connected: false})
.cursor({batchSize: 100})
.eachAsync(function(Player) {
var idleTime = Math.floor((new Date().getTime() - new Date(Player.lastactivity).getTime()) / 60000);
if (idleTime >= 10)
toRemove.push(Player._id);
}, function() {
if (toRemove.length > 0) {
console.log("Removing " + toRemove.length + " idle players.");
schemas.Player.remove({_id: {$in: toRemove}}, function(err) {
if (err)
deferred.reject(err);
else
deferred.resolve();
});
}
});
return deferred.promise;
}