2017-03-30 00:37:30 +09:00
|
|
|
const _ = require('underscore');
|
|
|
|
const EventEmitter = require('events').EventEmitter;
|
2016-12-06 21:33:31 -05:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
const getPluginsFor = function (pluginType, plugins) {
|
|
|
|
return _.filter(plugins, pluginType);
|
|
|
|
};
|
|
|
|
|
|
|
|
class Plugins extends EventEmitter {
|
|
|
|
constructor(options) {
|
|
|
|
super();
|
|
|
|
//TODO: put an observer on this.plugins and call loadPlugin when a new item is added
|
|
|
|
this.config = {};
|
|
|
|
|
|
|
|
const loadPlugins = this.load;
|
|
|
|
for (let opt in options) {
|
|
|
|
if (options.hasOwnProperty(opt)) {
|
|
|
|
this.config[opt] = options[opt];
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
}
|
2016-12-06 21:33:31 -05:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
let requiredOptions = ['interceptLogs', 'plugins', 'logger'];
|
|
|
|
for (let i = 0; requiredOptions.length > i; i++) {
|
|
|
|
if (!(_.contains(Object.keys(this.config), requiredOptions[i]))) {
|
|
|
|
console.log('Warning: missing required plugin configuration key: ' + requiredOptions[i]);
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
this.on('load', () => {
|
|
|
|
this.load();
|
|
|
|
});
|
|
|
|
|
|
|
|
this.on('get', (pluginType, cb) => {
|
|
|
|
let pluginTypes = getPluginsFor(pluginType, this.config.plugins);
|
|
|
|
return cb(pluginTypes);
|
|
|
|
});
|
2017-01-15 14:30:41 -05:00
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
load() {
|
|
|
|
let pluginConfig;
|
|
|
|
for (let i = 0; this.config.plugins.length > i; i++) {
|
|
|
|
pluginConfig = this.config.plugins[i].config;
|
|
|
|
let Plugin = require('./plugin');
|
|
|
|
let plugin = new Plugin(pluginConfig);
|
|
|
|
plugin.run();
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
}
|
2016-12-06 21:33:31 -05:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
listPlugins() {
|
|
|
|
return this.config.plugins.join(', ');
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
|
|
|
|
module.exports = Plugins;
|