mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-09 21:35:58 +00:00
55 lines
1.5 KiB
JavaScript
55 lines
1.5 KiB
JavaScript
var async = require('async');
|
|
|
|
// TODO: repeated, add this to an async extensions file
|
|
function asyncEachObject(object, iterator, callback) {
|
|
async.each(
|
|
Object.keys(object || {}),
|
|
function(key, next){
|
|
iterator(key, object[key], next);
|
|
},
|
|
callback
|
|
);
|
|
}
|
|
async.eachObject = asyncEachObject;
|
|
|
|
var ServicesMonitor = function(options) {
|
|
this.events = options.events;
|
|
this.logger = options.logger;
|
|
this.checkList = {};
|
|
this.checkTimers = {};
|
|
this.checkState = {};
|
|
};
|
|
|
|
ServicesMonitor.prototype.addCheck = function(name, checkFn, time) {
|
|
this.logger.info('add check: ' + name);
|
|
// TODO: check if a service with the same name already exists
|
|
this.checkList[name] = {fn: checkFn, interval: time || 5000};
|
|
};
|
|
|
|
ServicesMonitor.prototype.startMonitor = function() {
|
|
this.logger.info('startMonitor');
|
|
var self = this;
|
|
|
|
async.eachObject(this.checkList, function(checkName, check, callback) {
|
|
self.events.on('check:' + checkName, function(obj) {
|
|
self.checkState[checkName] = obj.name[obj.status];
|
|
self.events.emit("servicesState", self.checkState);
|
|
});
|
|
|
|
if (check.interval !== 0) {
|
|
self.checkTimers[checkName] = setInterval(function() {
|
|
check.fn.call(check.fn, function(obj) {
|
|
self.events.emit('check:' + checkName, obj);
|
|
});
|
|
}, check.interval);
|
|
}
|
|
|
|
check.fn.call(check.fn, function(obj) {
|
|
self.events.emit('check:' + checkName, obj);
|
|
});
|
|
}, function(err) {
|
|
});
|
|
};
|
|
|
|
module.exports = ServicesMonitor;
|