mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-09 13:26:10 +00:00
4ce7a179fd
First case - run `embark run` which starts a blockchain node, then manually kill the `geth` process. Would throw `{ [Error: connect ECONNREFUSED 127.0.0.1:8543] message: 'connect ECONNREFUSED 127.0.0.1:8543', code: -32603 }` error and ruins the dashboard. Second case, 1) run `embark blockchain` 2) run `embark run` 3) kill `embark blockchain` throws the error `{ [Error: connect ECONNREFUSED 127.0.0.1:8543] message: 'connect ECONNREFUSED 127.0.0.1:8543', code: -32603 }` and ruins the dashboard. The first case was solved by having the child blockchain process that spawns geth listen for geth exit, then kill itself. The second case required updating of `eth-block-tracker` to v4.0.1 inside of the `embark-web3-provider-engine`. v4.0.1 was a major version update and introduced breaking changes. Those changes were handled inside of `embark-web3-provider-engine`, covered in **blocker** PR https://github.com/jrainville/provider-engine/pull/1.
63 lines
1.9 KiB
JavaScript
63 lines
1.9 KiB
JavaScript
const ProcessLauncher = require('../process/processLauncher');
|
|
const utils = require('../utils/utils.js');
|
|
const constants = require('../constants');
|
|
|
|
class BlockchainProcessLauncher {
|
|
|
|
constructor (options) {
|
|
this.events = options.events;
|
|
this.logger = options.logger;
|
|
this.normalizeInput = options.normalizeInput;
|
|
this.blockchainConfig = options.blockchainConfig;
|
|
this.locale = options.locale;
|
|
this.isDev = options.isDev;
|
|
}
|
|
|
|
processEnded(code) {
|
|
this.logger.error(__('Blockchain process ended before the end of this process. Code: %s', code));
|
|
}
|
|
|
|
startBlockchainNode() {
|
|
this.logger.info(__('Starting Blockchain node in another process').cyan);
|
|
|
|
this.blockchainProcess = new ProcessLauncher({
|
|
modulePath: utils.joinPath(__dirname, '../cmds/blockchain/blockchainProcess.js'),
|
|
logger: this.logger,
|
|
events: this.events,
|
|
silent: this.logger.logLevel !== 'trace',
|
|
exitCallback: this.processEnded.bind(this)
|
|
});
|
|
this.blockchainProcess.send({
|
|
action: constants.blockchain.init, options: {
|
|
blockchainConfig: this.blockchainConfig,
|
|
//client: this.client,
|
|
// TODO: assume for now it's geth
|
|
client: 'geth',
|
|
env: this.env,
|
|
isDev: this.isDev,
|
|
locale: this.locale
|
|
}
|
|
});
|
|
|
|
this.blockchainProcess.once('result', constants.blockchain.blockchainReady, () => {
|
|
this.logger.info(__('Blockchain node is ready').cyan);
|
|
this.events.emit(constants.blockchain.blockchainReady);
|
|
});
|
|
|
|
this.blockchainProcess.once('result', constants.blockchain.blockchainExit, () => {
|
|
// telle everyone that our blockchain process (ie geth) died
|
|
this.events.emit(constants.blockchain.blockchainExit);
|
|
|
|
// then kill off the blockchain process
|
|
this.blockchainProcess.kill();
|
|
});
|
|
|
|
this.events.on('exit', () => {
|
|
this.blockchainProcess.send('exit');
|
|
});
|
|
}
|
|
|
|
}
|
|
|
|
module.exports = BlockchainProcessLauncher;
|