2018-05-28 12:54:06 -04:00
|
|
|
const child_process = require('child_process');
|
2018-07-27 17:33:50 -04:00
|
|
|
const ProcessWrapper = require('../../core/processes/processWrapper');
|
2018-05-28 11:50:01 -04:00
|
|
|
const constants = require('../../constants');
|
2018-05-28 15:37:25 -04:00
|
|
|
const fs = require('../../core/fs');
|
2018-05-28 11:50:01 -04:00
|
|
|
|
|
|
|
let swarmProcess;
|
|
|
|
|
|
|
|
class SwarmProcess extends ProcessWrapper {
|
|
|
|
constructor(options) {
|
|
|
|
super();
|
|
|
|
this.storageConfig = options.storageConfig;
|
2018-09-13 13:37:44 +01:00
|
|
|
this.blockchainConfig = options.blockchainConfig;
|
2018-05-31 20:18:25 +10:00
|
|
|
this.cors = options.cors;
|
2018-07-20 17:54:02 +03:00
|
|
|
this.command = this.storageConfig.swarmPath || 'swarm';
|
2018-05-28 11:50:01 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
startSwarmDaemon() {
|
2018-05-28 11:52:49 -04:00
|
|
|
const self = this;
|
2018-05-28 11:50:39 -04:00
|
|
|
if (!this.storageConfig.account || !this.storageConfig.account.address || !this.storageConfig.account.password) {
|
2018-05-28 11:50:01 -04:00
|
|
|
return 'Account address and password are needed in the storage config to start the Swarm process';
|
|
|
|
}
|
2018-05-28 15:37:25 -04:00
|
|
|
|
2018-09-13 13:37:44 +01:00
|
|
|
const datadir = this.blockchainConfig.datadir || fs.dappPath(`.embark/development/datadir`);
|
2018-05-28 15:37:25 -04:00
|
|
|
const args = [
|
2018-09-13 13:37:44 +01:00
|
|
|
'--datadir', datadir,
|
|
|
|
'--bzzaccount', this.storageConfig.account.address,
|
|
|
|
'--password', fs.dappPath(this.storageConfig.account.password),
|
|
|
|
'--corsdomain', self.cors.join(',')
|
|
|
|
];
|
|
|
|
|
2018-07-30 16:03:02 -04:00
|
|
|
console.trace('Starting swarm process with arguments: ' + args.join(' '));
|
2018-06-08 10:40:01 -04:00
|
|
|
this.child = child_process.spawn(this.command, args);
|
2018-05-28 15:37:25 -04:00
|
|
|
|
2018-05-30 12:58:32 -04:00
|
|
|
this.child.on('error', (err) => {
|
2018-05-28 15:37:25 -04:00
|
|
|
err = err.toString();
|
|
|
|
console.error('Swarm error: ', err);
|
|
|
|
});
|
2018-05-30 12:58:32 -04:00
|
|
|
this.child.stdout.on('data', (data) => {
|
2018-05-28 15:37:25 -04:00
|
|
|
data = data.toString();
|
|
|
|
console.log(`Swarm error: ${data}`);
|
|
|
|
});
|
2018-05-28 16:02:44 -04:00
|
|
|
// Swarm logs appear in stderr somehow
|
2018-05-30 12:58:32 -04:00
|
|
|
this.child.stderr.on('data', (data) => {
|
2018-05-28 15:37:25 -04:00
|
|
|
data = data.toString();
|
2018-05-24 10:25:32 -04:00
|
|
|
if (!self.readyCalled && data.indexOf('Swarm http proxy started') > -1) {
|
|
|
|
self.readyCalled = true;
|
|
|
|
self.send({result: constants.storage.initiated});
|
|
|
|
}
|
|
|
|
console.log('Swarm: ' + data);
|
|
|
|
});
|
2018-05-30 12:58:32 -04:00
|
|
|
this.child.on('exit', (code) => {
|
2018-05-24 10:25:32 -04:00
|
|
|
if (code) {
|
|
|
|
console.error('Swarm exited with error code ' + code);
|
|
|
|
}
|
|
|
|
});
|
2018-05-28 11:50:01 -04:00
|
|
|
}
|
2018-05-30 12:58:32 -04:00
|
|
|
|
|
|
|
kill() {
|
|
|
|
if (this.child) {
|
|
|
|
this.child.kill();
|
|
|
|
}
|
|
|
|
}
|
2018-05-28 11:50:01 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
process.on('message', (msg) => {
|
2018-05-30 12:58:32 -04:00
|
|
|
if (msg === 'exit') {
|
|
|
|
return swarmProcess.kill();
|
|
|
|
}
|
2018-05-28 11:50:01 -04:00
|
|
|
if (msg.action === constants.storage.init) {
|
|
|
|
swarmProcess = new SwarmProcess(msg.options);
|
|
|
|
const error = swarmProcess.startSwarmDaemon();
|
|
|
|
|
2018-05-24 10:25:32 -04:00
|
|
|
if (error) {
|
|
|
|
swarmProcess.send({result: constants.storage.initiated, error});
|
|
|
|
}
|
2018-05-28 11:50:01 -04:00
|
|
|
}
|
|
|
|
});
|