2017-06-11 00:29:00 +00:00
|
|
|
/* jslint node: true */
|
|
|
|
'use strict';
|
|
|
|
|
2017-06-23 04:19:34 +00:00
|
|
|
const paths = require('path');
|
|
|
|
const events = require('events');
|
|
|
|
const Log = require('./logger.js').log;
|
2018-06-03 23:02:28 +00:00
|
|
|
const SystemEvents = require('./system_events.js');
|
2017-06-23 04:19:34 +00:00
|
|
|
|
|
|
|
// deps
|
|
|
|
const _ = require('lodash');
|
|
|
|
const async = require('async');
|
|
|
|
const glob = require('glob');
|
|
|
|
|
|
|
|
module.exports = new class Events extends events.EventEmitter {
|
|
|
|
constructor() {
|
|
|
|
super();
|
2018-06-22 00:37:48 +00:00
|
|
|
this.setMaxListeners(32); // :TODO: play with this...
|
2017-06-23 04:19:34 +00:00
|
|
|
}
|
|
|
|
|
2018-03-04 20:34:35 +00:00
|
|
|
getSystemEvents() {
|
2018-06-03 23:02:28 +00:00
|
|
|
return SystemEvents;
|
2018-03-04 20:34:35 +00:00
|
|
|
}
|
|
|
|
|
2017-06-23 04:19:34 +00:00
|
|
|
addListener(event, listener) {
|
|
|
|
Log.trace( { event : event }, 'Registering event listener');
|
|
|
|
return super.addListener(event, listener);
|
|
|
|
}
|
|
|
|
|
|
|
|
emit(event, ...args) {
|
|
|
|
Log.trace( { event : event }, 'Emitting event');
|
2018-03-04 04:16:01 +00:00
|
|
|
return super.emit(event, ...args);
|
2017-06-23 04:19:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
on(event, listener) {
|
|
|
|
Log.trace( { event : event }, 'Registering event listener');
|
|
|
|
return super.on(event, listener);
|
|
|
|
}
|
|
|
|
|
|
|
|
once(event, listener) {
|
|
|
|
Log.trace( { event : event }, 'Registering single use event listener');
|
|
|
|
return super.once(event, listener);
|
|
|
|
}
|
|
|
|
|
|
|
|
removeListener(event, listener) {
|
|
|
|
Log.trace( { event : event }, 'Removing listener');
|
|
|
|
return super.removeListener(event, listener);
|
|
|
|
}
|
|
|
|
|
|
|
|
startup(cb) {
|
|
|
|
async.each(require('./module_util.js').getModulePaths(), (modulePath, nextPath) => {
|
|
|
|
glob('*{.js,/*.js}', { cwd : modulePath }, (err, files) => {
|
|
|
|
if(err) {
|
|
|
|
return nextPath(err);
|
2017-06-12 02:44:34 +00:00
|
|
|
}
|
2017-06-23 04:19:34 +00:00
|
|
|
|
|
|
|
async.each(files, (moduleName, nextModule) => {
|
2018-01-15 16:41:18 +00:00
|
|
|
const fullModulePath = paths.join(modulePath, moduleName);
|
2017-06-23 04:19:34 +00:00
|
|
|
|
|
|
|
try {
|
2018-01-15 16:41:18 +00:00
|
|
|
const mod = require(fullModulePath);
|
|
|
|
|
2017-06-23 04:19:34 +00:00
|
|
|
if(_.isFunction(mod.registerEvents)) {
|
|
|
|
// :TODO: ... or just systemInit() / systemShutdown() & mods could call Events.on() / Events.removeListener() ?
|
|
|
|
mod.registerEvents(this);
|
|
|
|
}
|
|
|
|
} catch(e) {
|
2018-01-15 16:41:18 +00:00
|
|
|
Log.warn( { error : e }, 'Exception during module "registerEvents"');
|
2017-06-12 02:44:34 +00:00
|
|
|
}
|
2017-06-23 04:19:34 +00:00
|
|
|
|
|
|
|
return nextModule(null);
|
|
|
|
}, err => {
|
|
|
|
return nextPath(err);
|
|
|
|
});
|
2017-06-12 02:44:34 +00:00
|
|
|
});
|
2017-06-23 04:19:34 +00:00
|
|
|
}, err => {
|
|
|
|
return cb(err);
|
2017-06-11 00:29:00 +00:00
|
|
|
});
|
|
|
|
}
|
2017-06-23 04:19:34 +00:00
|
|
|
};
|