fix swarm spawn

This commit is contained in:
Jonathan Rainville 2018-05-28 15:37:25 -04:00
parent c86c50fb4e
commit d06a7f43ac
1 changed files with 23 additions and 8 deletions

View File

@ -1,6 +1,7 @@
const child_process = require('child_process'); const child_process = require('child_process');
const ProcessWrapper = require('../../process/processWrapper'); const ProcessWrapper = require('../../process/processWrapper');
const constants = require('../../constants'); const constants = require('../../constants');
const fs = require('../../core/fs');
let swarmProcess; let swarmProcess;
@ -20,15 +21,27 @@ class SwarmProcess extends ProcessWrapper {
if (self.webServerConfig && self.webServerConfig && self.webServerConfig.host && self.webServerConfig.port) { if (self.webServerConfig && self.webServerConfig && self.webServerConfig.host && self.webServerConfig.port) {
corsDomain = `http://${self.webServerConfig.host}:${self.webServerConfig.port}`; corsDomain = `http://${self.webServerConfig.host}:${self.webServerConfig.port}`;
} }
const child = child_process.spawn(this.storageConfig.swarmPath || 'swarm',
[ const args = [
`--bzzaccount ${this.storageConfig.account.address}`, `--bzzaccount=${this.storageConfig.account.address}`,
`--password ${this.storageConfig.account.password}`, `--password=${fs.dappPath(this.storageConfig.account.password)}`,
`--corsdomain ${corsDomain}`, `--corsdomain=${corsDomain}`,
"--ens-api ''" `--ens-api=''`
]); ];
const child = child_process.spawn(this.storageConfig.swarmPath || 'swarm', args, {shell: true});
child.on('error', (err) => {
err = err.toString();
console.error('Swarm error: ', err);
});
let lastMessage; let lastMessage;
child.stdout.on('data', (data) => {
data = data.toString();
console.log(`Swarm error: ${data}`);
});
// Geth logs appear in stderr somehow
child.stderr.on('data', (data) => { child.stderr.on('data', (data) => {
data = data.toString();
if (!self.readyCalled && data.indexOf('Swarm http proxy started') > -1) { if (!self.readyCalled && data.indexOf('Swarm http proxy started') > -1) {
self.readyCalled = true; self.readyCalled = true;
self.send({result: constants.storage.initiated}); self.send({result: constants.storage.initiated});
@ -39,8 +52,10 @@ class SwarmProcess extends ProcessWrapper {
child.on('exit', (code) => { child.on('exit', (code) => {
if (code) { if (code) {
console.error('Swarm exited with error code ' + code); console.error('Swarm exited with error code ' + code);
if (lastMessage) {
console.error(lastMessage); console.error(lastMessage);
} }
}
}); });
} }
} }