mirror of
https://github.com/status-im/embark-area-51.git
synced 2025-01-24 06:08:48 +00:00
42cc9b559f
A logfile is now generated by default, in the format `.embark/embark-log__YYYY-MM-DD_HH-mm-ss.log`. When the home tab is loaded, the process logs are fetched for all the processes. The list of processes returned now includes `embark`, and when `/embark-api/process-logs/embark` is fetched, the logFile is parsed and an array of log messages are returned.
56 lines
1.4 KiB
JavaScript
56 lines
1.4 KiB
JavaScript
|
|
class ProcessManager {
|
|
constructor(options) {
|
|
this.logger = options.logger;
|
|
this.events = options.events;
|
|
this.plugins = options.plugins;
|
|
this.processes = {};
|
|
|
|
this._registerAsPlugin();
|
|
this._registerEvents();
|
|
}
|
|
|
|
_registerAsPlugin() {
|
|
const self =this;
|
|
self.plugin = this.plugins.createPlugin('processManager', {});
|
|
self.plugin.registerAPICall(
|
|
'get',
|
|
'/embark-api/processes',
|
|
(req, res) => {
|
|
const formatter = (acc, processName) => {
|
|
acc.push({state: self.processes[processName].state, name: processName});
|
|
return acc;
|
|
};
|
|
// add "embark" process to list of running processes
|
|
res.send(Object.keys(self.processes).reduce(formatter, []).concat({ state: "running", name: "embark" }));
|
|
}
|
|
);
|
|
}
|
|
|
|
_registerEvents() {
|
|
const self = this;
|
|
self.events.setCommandHandler('processes:register', (name, cb) => {
|
|
this.processes[name] = {
|
|
state: 'unstarted',
|
|
cb: cb
|
|
};
|
|
});
|
|
|
|
self.events.setCommandHandler('processes:launch', (name, cb) => {
|
|
let process = self.processes[name];
|
|
if (process.state !== 'unstarted') {
|
|
return cb();
|
|
}
|
|
process.state = 'starting';
|
|
process.cb.apply(process.cb, [
|
|
() => {
|
|
process.state = 'running';
|
|
cb();
|
|
}
|
|
]);
|
|
});
|
|
}
|
|
}
|
|
|
|
module.exports = ProcessManager;
|