small conflicts

This commit is contained in:
Jonathan Rainville 2018-08-01 11:14:02 -04:00 committed by Iuri Matias
parent 775238af4c
commit 665d344a54
7 changed files with 65 additions and 13 deletions

View File

@ -18,7 +18,7 @@ Logger.prototype.registerAPICall = function (plugins) {
plugin.registerAPICall( plugin.registerAPICall(
'ws', 'ws',
'/embark-api/logs', '/embark-api/logs',
(ws, req) => { (ws, _req) => {
self.events.on("log", function(logLevel, logMsg) { self.events.on("log", function(logLevel, logMsg) {
ws.send(JSON.stringify({msg: logMsg, msg_clear: logMsg.stripColors, logLevel: logLevel}), () => {}); ws.send(JSON.stringify({msg: logMsg, msg_clear: logMsg.stripColors, logLevel: logLevel}), () => {});
}); });
@ -26,7 +26,7 @@ Logger.prototype.registerAPICall = function (plugins) {
); );
}; };
Logger.prototype.writeToFile = function (txt) { Logger.prototype.writeToFile = function (_txt) {
if (!this.logfile) { if (!this.logfile) {
return; return;
} }

View File

@ -24,6 +24,7 @@ var Plugin = function(options) {
this.pluginTypes = []; this.pluginTypes = [];
this.uploadCmds = []; this.uploadCmds = [];
this.apiCalls = []; this.apiCalls = [];
this.processes = [];
this.imports = []; this.imports = [];
this.embarkjs_code = []; this.embarkjs_code = [];
this.embarkjs_init_code = {}; this.embarkjs_init_code = {};
@ -213,7 +214,12 @@ Plugin.prototype.registerActionForEvent = function(eventName, cb) {
Plugin.prototype.registerAPICall = function(method, endpoint, cb) { Plugin.prototype.registerAPICall = function(method, endpoint, cb) {
console.dir("registerAPICall " + method + " " + endpoint); console.dir("registerAPICall " + method + " " + endpoint);
this.apiCalls.push({method: method, endpoint: endpoint, cb: cb}); this.apiCalls.push({method: method, endpoint: endpoint, cb: cb});
this.pluginTypes.push('apiCalls'); this.addPluginType('apiCalls');
};
Plugin.prototype.registerProcess = function(processName) {
this.processes.push({processName});
this.addPluginType('processes');
}; };
Plugin.prototype.runFilePipeline = function() { Plugin.prototype.runFilePipeline = function() {

View File

@ -14,15 +14,19 @@ class ProcessLauncher {
* @return {ProcessLauncher} The ProcessLauncher instance * @return {ProcessLauncher} The ProcessLauncher instance
*/ */
constructor(options) { constructor(options) {
this.name = path.basename(options.modulePath); this.name = options.name || path.basename(options.modulePath);
this.process = child_process.fork(options.modulePath); this.process = child_process.fork(options.modulePath);
this.logger = options.logger; this.logger = options.logger;
this.events = options.events; this.events = options.events;
this.silent = options.silent; this.silent = options.silent;
this.exitCallback = options.exitCallback; this.exitCallback = options.exitCallback;
this.embark = options.embark;
this.subscriptions = {}; this.subscriptions = {};
this._subscribeToMessages(); this._subscribeToMessages();
if (this.embark) {
this._registerAsPlugin();
}
} }
// Subscribes to messages from the child process and delegates to the right methods // Subscribes to messages from the child process and delegates to the right methods
@ -48,8 +52,22 @@ class ProcessLauncher {
}); });
} }
_registerAsPlugin() {
const self = this;
self.embark.registerAPICall(
'ws',
'/embark/process-logs/' + self.name,
(ws, _req) => {
self.events.on('log-' + self.name, function(logLevel, msg) {
ws.send(JSON.stringify({msg, msg_clear: msg.stripColors, logLevel}), () => {});
});
}
);
}
// Translates logs from the child process to the logger // Translates logs from the child process to the logger
_handleLog(msg) { _handleLog(msg) {
this.events.emit('log-' + this.name, msg.type, msg.message);
if (this.silent && msg.type !== 'error') { if (this.silent && msg.type !== 'error') {
return; return;
} }

View File

@ -1,12 +1,35 @@
class ProcessManager { class ProcessManager {
constructor(options) { constructor(options) {
const self = this;
this.logger = options.logger; this.logger = options.logger;
this.events = options.events; this.events = options.events;
this.plugins = options.plugins; this.plugins = options.plugins;
this.processes = {}; this.processes = {};
this._registerAsPlugin();
this._registerEvents();
}
_registerAsPlugin() {
const self =this;
self.plugin = this.plugins.createPlugin('processManager', {});
self.plugin.registerAPICall(
'get',
'/embark/processes',
(req, res) => {
let parsedProcesses = {};
Object.keys(self.processes).forEach(processName => {
parsedProcesses[processName] = {
state: self.processes[processName]
};
});
res.send(parsedProcesses);
}
);
}
_registerEvents() {
const self = this;
self.events.setCommandHandler('processes:register', (name, cb) => { self.events.setCommandHandler('processes:register', (name, cb) => {
this.processes[name] = { this.processes[name] = {
state: 'unstarted', state: 'unstarted',
@ -16,7 +39,7 @@ class ProcessManager {
self.events.setCommandHandler('processes:launch', (name, cb) => { self.events.setCommandHandler('processes:launch', (name, cb) => {
let process = self.processes[name]; let process = self.processes[name];
if (process.state != 'unstarted') { if (process.state !== 'unstarted') {
return cb(); return cb();
} }
process.state = 'starting'; process.state = 'starting';
@ -28,7 +51,6 @@ class ProcessManager {
]); ]);
}); });
} }
} }
module.exports = ProcessManager; module.exports = ProcessManager;

View File

@ -19,6 +19,10 @@ class IPFS {
this.webServerConfig = embark.config.webServerConfig; this.webServerConfig = embark.config.webServerConfig;
this.blockchainConfig = embark.config.blockchainConfig; this.blockchainConfig = embark.config.blockchainConfig;
this.events.request('processes:register', 'ipfs', (cb) => {
self.startProcess(cb);
});
if (this.isIpfsStorageEnabledInTheConfig() || this.isIpfsNameEnabledInTheConfig()) { if (this.isIpfsStorageEnabledInTheConfig() || this.isIpfsNameEnabledInTheConfig()) {
this.downloadIpfsApi(); this.downloadIpfsApi();
this.addDefaultToEmbarkJS(); this.addDefaultToEmbarkJS();
@ -35,7 +39,7 @@ class IPFS {
return; return;
} }
self.logger.info("IPFS node not found, attempting to start own node"); self.logger.info("IPFS node not found, attempting to start own node");
self.startProcess(() => {}); this.events.request("processes:launch", "ipfs", () => {});
}); });
} }
@ -145,7 +149,8 @@ class IPFS {
events: self.events, events: self.events,
storageConfig: self.storageConfig, storageConfig: self.storageConfig,
webServerConfig: self.webServerConfig, webServerConfig: self.webServerConfig,
blockchainConfig: self.blockchainConfig blockchainConfig: self.blockchainConfig,
embark: self.embark
}); });
self.logger.trace(`Storage module: Launching ipfs process...`); self.logger.trace(`Storage module: Launching ipfs process...`);
return storageProcessesLauncher.launchProcess('ipfs', callback); return storageProcessesLauncher.launchProcess('ipfs', callback);

View File

@ -17,6 +17,7 @@ class StorageProcessesLauncher {
this.storageConfig = options.storageConfig; this.storageConfig = options.storageConfig;
this.webServerConfig = options.webServerConfig; this.webServerConfig = options.webServerConfig;
this.blockchainConfig = options.blockchainConfig; this.blockchainConfig = options.blockchainConfig;
this.embark = options.embark;
this.processes = {}; this.processes = {};
this.cors = this.buildCors(); this.cors = this.buildCors();
@ -105,8 +106,10 @@ class StorageProcessesLauncher {
self.logger.info(__(`Starting %s process`, storageName).cyan); self.logger.info(__(`Starting %s process`, storageName).cyan);
self.processes[storageName] = new ProcessLauncher({ self.processes[storageName] = new ProcessLauncher({
modulePath: filePath, modulePath: filePath,
name: storageName,
logger: self.logger, logger: self.logger,
events: self.events, events: self.events,
embark: self.embark,
silent: self.logger.logLevel !== 'trace', silent: self.logger.logLevel !== 'trace',
exitCallback: self.processExited.bind(this, storageName) exitCallback: self.processExited.bind(this, storageName)
}); });

View File

@ -1,5 +1,3 @@
let finalhandler = require('finalhandler');
let http = require('http');
let serveStatic = require('serve-static'); let serveStatic = require('serve-static');
const {canonicalHost, defaultHost, dockerHostSwap} = require('../../utils/host'); const {canonicalHost, defaultHost, dockerHostSwap} = require('../../utils/host');
require('http-shutdown').extend(); require('http-shutdown').extend();
@ -32,7 +30,7 @@ class Server {
app.use('/embark', express.static(path.join(__dirname, '../../../embark-ui/build'))); app.use('/embark', express.static(path.join(__dirname, '../../../embark-ui/build')));
app.use(bodyParser.json()); // support json encoded bodies app.use(bodyParser.json()); // support json encoded bodies
app.use(bodyParser.urlencoded({ extended: true })); // support encoded bodies app.use(bodyParser.urlencoded({extended: true})); // support encoded bodies
expressWebSocket(app); expressWebSocket(app);