2016-12-06 21:33:31 -05:00
|
|
|
var Plugin = require('./plugin.js');
|
2017-02-18 15:07:19 -05:00
|
|
|
var utils = require('./utils.js');
|
2016-12-06 21:33:31 -05:00
|
|
|
|
|
|
|
var Plugins = function(options) {
|
|
|
|
this.pluginList = options.plugins || [];
|
2017-02-06 06:42:58 -05:00
|
|
|
this.interceptLogs = options.interceptLogs;
|
2016-12-06 21:33:31 -05:00
|
|
|
this.plugins = [];
|
2017-01-15 14:30:41 -05:00
|
|
|
// TODO: need backup 'NullLogger'
|
|
|
|
this.logger = options.logger;
|
2016-12-06 21:33:31 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
Plugins.prototype.loadPlugins = function() {
|
2017-01-15 14:30:41 -05:00
|
|
|
var pluginConfig;
|
|
|
|
for (var pluginName in this.pluginList) {
|
|
|
|
pluginConfig = this.pluginList[pluginName];
|
|
|
|
this.loadPlugin(pluginName, pluginConfig);
|
2016-12-06 21:33:31 -05:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-01-15 14:30:41 -05:00
|
|
|
Plugins.prototype.listPlugins = function() {
|
|
|
|
var list = [];
|
|
|
|
for (var className in this.pluginList) {
|
|
|
|
list.push(className);
|
|
|
|
}
|
|
|
|
return list;
|
|
|
|
};
|
|
|
|
|
|
|
|
Plugins.prototype.loadPlugin = function(pluginName, pluginConfig) {
|
2017-02-18 14:10:01 -05:00
|
|
|
var pluginPath = utils.joinPath(process.env.PWD, 'node_modules', pluginName);
|
2017-01-26 06:34:00 -05:00
|
|
|
var plugin = require(pluginPath);
|
2016-12-06 21:33:31 -05:00
|
|
|
|
2017-02-06 06:42:58 -05:00
|
|
|
var pluginWrapper = new Plugin({name: pluginName, pluginModule: plugin, pluginConfig: pluginConfig, logger: this.logger, pluginPath: pluginPath, interceptLogs: this.interceptLogs});
|
2016-12-06 21:33:31 -05:00
|
|
|
pluginWrapper.loadPlugin();
|
|
|
|
this.plugins.push(pluginWrapper);
|
|
|
|
};
|
|
|
|
|
|
|
|
Plugins.prototype.getPluginsFor = function(pluginType) {
|
|
|
|
return this.plugins.filter(function(plugin) {
|
|
|
|
return plugin.has(pluginType);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = Plugins;
|