2017-01-15 14:30:41 -05:00
|
|
|
/*jshint esversion: 6, loopfunc: true */
|
2017-03-30 00:37:30 +09:00
|
|
|
let fs = require('./fs.js');
|
|
|
|
let utils = require('../utils/utils.js');
|
|
|
|
let camelcase = require("underscore.string").camelcase;
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
class Plugin {
|
|
|
|
constructor(options) {
|
|
|
|
this.config = {};
|
|
|
|
for (let opt in options) {
|
|
|
|
if (options.hasOwnProperty(opt)) {
|
|
|
|
this.config[opt] = options[opt];
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
let requiredOptions = ['name', 'pluginModule', 'pluginPath', 'config', 'interceptLogs', 'logger'];
|
2017-03-30 00:37:30 +09:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
for (let i = 0; requiredOptions.length > i; i++) {
|
|
|
|
if (!(utils.contains(Object.keys(this.config), requiredOptions[i]))) {
|
|
|
|
throw new Error('Missing required plugin configuration key: ' + requiredOptions[i]);
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
}
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
this.clientWeb3Providers = [];
|
|
|
|
this.contractsGenerators = [];
|
|
|
|
this.pipeline = [];
|
|
|
|
this.pipelineFiles = [];
|
|
|
|
this.console = [];
|
|
|
|
this.contractsConfigs = [];
|
|
|
|
this.contractsFiles = [];
|
|
|
|
this.compilers = [];
|
|
|
|
this.serviceChecks = [];
|
|
|
|
this.pluginTypes = [];
|
|
|
|
|
|
|
|
if (!(this instanceof Plugin)) {
|
|
|
|
return new Plugin();
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
}
|
2016-12-06 21:33:31 -05:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.runPlugin = Plugin.prototype.run = function () {
|
2017-02-06 06:42:58 -05:00
|
|
|
if (this.shouldInterceptLogs) {
|
|
|
|
this.interceptLogs(this.pluginModule);
|
|
|
|
}
|
2017-03-30 00:37:30 +09:00
|
|
|
let fullyQualifiedPath = this.pathToFile(this.config.pluginModule);
|
|
|
|
this.call(this.loadPluginFile(fullyQualifiedPath), this);
|
2016-12-06 21:33:31 -05:00
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.loadPluginFile = function (filename) {
|
2017-01-26 06:34:00 -05:00
|
|
|
return fs.readFileSync(this.pathToFile(filename)).toString();
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.pathToFile = function (filename) {
|
2017-02-18 14:10:01 -05:00
|
|
|
return utils.joinPath(this.pluginPath, filename);
|
2017-01-26 06:34:00 -05:00
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.interceptLogs = function (context) {
|
2017-03-30 00:37:30 +09:00
|
|
|
let self = this;
|
2017-02-06 06:42:58 -05:00
|
|
|
// TODO: this is a bit nasty, figure out a better way
|
|
|
|
context.console = context.console || console;
|
2017-02-26 18:47:52 -05:00
|
|
|
|
|
|
|
//context.console.error = function(txt) {
|
|
|
|
// // TODO: logger should support an array instead of a single argument
|
|
|
|
// //self.logger.error.apply(self.logger, arguments);
|
|
|
|
// self.logger.error(self.name + " > " + txt);
|
|
|
|
//};
|
2017-03-30 20:12:39 +09:00
|
|
|
context.console.log = function (txt) {
|
2017-01-16 07:00:41 -05:00
|
|
|
self.logger.info(self.name + " > " + txt);
|
|
|
|
};
|
2017-03-30 20:12:39 +09:00
|
|
|
context.console.warn = function (txt) {
|
2017-01-16 07:00:41 -05:00
|
|
|
self.logger.warn(self.name + " > " + txt);
|
|
|
|
};
|
2017-03-30 20:12:39 +09:00
|
|
|
context.console.info = function (txt) {
|
2017-01-16 07:00:41 -05:00
|
|
|
self.logger.info(self.name + " > " + txt);
|
|
|
|
};
|
2017-03-30 20:12:39 +09:00
|
|
|
context.console.debug = function (txt) {
|
2017-01-26 06:34:00 -05:00
|
|
|
// TODO: ue JSON.stringify
|
2017-01-16 07:00:41 -05:00
|
|
|
self.logger.debug(self.name + " > " + txt);
|
|
|
|
};
|
2017-03-30 20:12:39 +09:00
|
|
|
context.console.trace = function (txt) {
|
2017-01-16 07:00:41 -05:00
|
|
|
self.logger.trace(self.name + " > " + txt);
|
|
|
|
};
|
2017-01-15 14:30:41 -05:00
|
|
|
};
|
|
|
|
|
2017-03-30 00:37:30 +09:00
|
|
|
Plugin.prototype.register = function (classname, cb) {
|
|
|
|
let camelCasedClassname = camelcase(classname);
|
|
|
|
this[camelCasedClassname].push(cb);
|
|
|
|
this.pluginTypes.push({class: classname, call: cb});
|
|
|
|
};
|
|
|
|
|
|
|
|
["ClientWeb3Provider", "ContractsGeneration", "Pipeline", "Deployer",
|
|
|
|
"ConsoleCommand", "ServiceCheck", "ContractConfiguration", "Compiler"].forEach(function (name) {
|
|
|
|
Plugin.prototype["register" + name] = function (cb) {
|
|
|
|
Plugin.prototype.register.call(name, cb);
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2016-12-06 21:33:31 -05:00
|
|
|
// TODO: add deploy provider
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.registerClientWeb3Provider = function (cb) {
|
2016-12-06 21:33:31 -05:00
|
|
|
this.clientWeb3Providers.push(cb);
|
|
|
|
this.pluginTypes.push('clientWeb3Provider');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.registerContractsGeneration = function (cb) {
|
2016-12-06 21:33:31 -05:00
|
|
|
this.contractsGenerators.push(cb);
|
|
|
|
this.pluginTypes.push('contractGeneration');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.registerPipeline = function (matcthingFiles, cb) {
|
2016-12-10 10:20:04 -05:00
|
|
|
// TODO: generate error for more than one pipeline per plugin
|
2017-01-15 14:30:41 -05:00
|
|
|
this.pipeline.push({matcthingFiles: matcthingFiles, cb: cb});
|
2016-12-10 10:20:04 -05:00
|
|
|
this.pluginTypes.push('pipeline');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.addFileToPipeline = function (file, intendedPath, options) {
|
2017-02-03 06:30:08 -05:00
|
|
|
this.pipelineFiles.push({file: file, intendedPath: intendedPath, options: options});
|
2017-01-26 06:34:00 -05:00
|
|
|
this.pluginTypes.push('pipelineFiles');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.addContractFile = function (file) {
|
2017-01-26 06:34:00 -05:00
|
|
|
this.contractsFiles.push(file);
|
|
|
|
this.pluginTypes.push('contractFiles');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.registerConsoleCommand = function (cb) {
|
2017-01-16 07:00:41 -05:00
|
|
|
this.console.push(cb);
|
|
|
|
this.pluginTypes.push('console');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.registerServiceCheck = function (checkName, checkFn, time) {
|
2017-03-16 07:31:52 -04:00
|
|
|
this.serviceChecks.push({checkName: checkName, checkFn: checkFn, time: time});
|
|
|
|
this.pluginTypes.push('serviceChecks');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.has = function (pluginType) {
|
2016-12-06 21:33:31 -05:00
|
|
|
return this.pluginTypes.indexOf(pluginType) >= 0;
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.generateProvider = function (args) {
|
|
|
|
return this.clientWeb3Providers.map(function (cb) {
|
2016-12-06 21:33:31 -05:00
|
|
|
return cb.call(this, args);
|
|
|
|
}).join("\n");
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.generateContracts = function (args) {
|
|
|
|
return this.contractsGenerators.map(function (cb) {
|
2016-12-06 21:33:31 -05:00
|
|
|
return cb.call(this, args);
|
|
|
|
}).join("\n");
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.registerContractConfiguration = function (config) {
|
2017-01-26 06:34:00 -05:00
|
|
|
this.contractsConfigs.push(config);
|
|
|
|
this.pluginTypes.push('contractsConfig');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.registerCompiler = function (extension, cb) {
|
2017-01-28 21:31:09 -05:00
|
|
|
this.compilers.push({extension: extension, cb: cb});
|
|
|
|
this.pluginTypes.push('compilers');
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.runCommands = function (cmd, options) {
|
|
|
|
return this.console.map(function (cb) {
|
2017-01-16 07:00:41 -05:00
|
|
|
return cb.call(this, cmd, options);
|
|
|
|
}).join("\n");
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.runFilePipeline = function () {
|
2017-03-30 00:37:30 +09:00
|
|
|
let self = this;
|
2017-01-26 06:34:00 -05:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
return this.pipelineFiles.map(function (file) {
|
|
|
|
let obj = {};
|
|
|
|
obj.filename = file.file.replace('./', '');
|
|
|
|
obj.content = self.loadPluginFile(file.file).toString();
|
|
|
|
obj.intendedPath = file.intendedPath;
|
|
|
|
obj.options = file.options;
|
|
|
|
obj.path = self.pathToFile(obj.filename);
|
2017-01-26 06:34:00 -05:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
return obj;
|
2017-01-26 06:34:00 -05:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
Plugin.prototype.runPipeline = function (args) {
|
2017-02-06 21:08:11 -05:00
|
|
|
// TODO: should iterate the pipelines
|
2017-03-30 00:37:30 +09:00
|
|
|
let pipeline = this.pipeline[0];
|
|
|
|
let shouldRunPipeline = utils.fileMatchesPattern(pipeline.matcthingFiles, args.targetFile);
|
2017-01-15 14:30:41 -05:00
|
|
|
if (shouldRunPipeline) {
|
|
|
|
return pipeline.cb.call(this, args);
|
|
|
|
} else {
|
|
|
|
return args.source;
|
|
|
|
}
|
2016-12-10 10:20:04 -05:00
|
|
|
};
|
|
|
|
|
2016-12-06 21:33:31 -05:00
|
|
|
module.exports = Plugin;
|