mirror of
https://github.com/reality/dbot.git
synced 2024-11-30 16:09:27 +01:00
67 lines
2.3 KiB
JavaScript
67 lines
2.3 KiB
JavaScript
/**
|
|
* Module Name: Timers
|
|
* Description: Persistent timers and shit
|
|
*/
|
|
var _ = require('underscore')._;
|
|
|
|
var timers = function(dbot) {
|
|
this.timers = dbot.db.timers;
|
|
this.runningTimeouts = [];
|
|
this.runningIntervals = [];
|
|
|
|
this.api = {
|
|
'addTimer': function(timeout, callback, firstDate) {
|
|
var now = new Date().getTime();
|
|
if(firstDate) {
|
|
console.log('Setting first timer to run at ' + firstDate);
|
|
firstTimeout = firstDate.getTime() - now;
|
|
this.runningTimeouts.push(setTimeout(function() {
|
|
console.log('Running first timer at ' + new Date().toUTCString());
|
|
this.runningIntervals.push(this.api.addTimer(timeout, callback));
|
|
try {
|
|
callback();
|
|
} catch(err) {
|
|
console.log('Callback failed: ' + err);
|
|
}
|
|
}.bind(this), firstTimeout));
|
|
} else {
|
|
this.runningIntervals.push(setInterval(function() {
|
|
console.log('Running subsequent timer at ' + new Date().toUTCString());
|
|
try {
|
|
callback();
|
|
} catch(err) {
|
|
console.log('Callback failed: ' + err);
|
|
}
|
|
}.bind(this), timeout));
|
|
}
|
|
},
|
|
|
|
'addTimeout': function(date, callback, params) {
|
|
var now = new Date().getTime(),
|
|
timeout = date.getTime() - now;
|
|
this.runningTimeouts.push(setTimeout(function() {
|
|
try {
|
|
callback.apply(callback, params);
|
|
} catch(err) {
|
|
console.log('Callback failed: ' + err);
|
|
}
|
|
}, timeout));
|
|
}
|
|
};
|
|
|
|
this.onDestroy = function() {
|
|
for(var i=0;i<this.runningTimeouts.length;i++) {
|
|
console.log('destroying ' +this.runningTimeouts[i]);
|
|
clearTimeout(this.runningTimeouts[i]);
|
|
}
|
|
for(i=0;i<this.runningIntervals.length;i++) {
|
|
console.log('destroying ' +this.runningIntervals[i]);
|
|
clearInterval(this.runningIntervals[i]);
|
|
}
|
|
}.bind(this);
|
|
};
|
|
|
|
exports.fetch = function(dbot) {
|
|
return new timers(dbot);
|
|
};
|