2018-05-30 16:34:36 +10:00
|
|
|
const UploadSwarm = require('./upload.js');
|
|
|
|
const utils = require('../../utils/utils.js');
|
|
|
|
const fs = require('../../core/fs.js');
|
|
|
|
const Web3Bzz = require('web3-bzz');
|
2018-05-31 20:18:25 +10:00
|
|
|
const _ = require('underscore');
|
2018-07-07 19:29:04 +03:00
|
|
|
const StorageProcessesLauncher = require('../../processes/storageProcesses/storageProcessesLauncher');
|
2017-12-26 19:55:42 -05:00
|
|
|
|
|
|
|
class Swarm {
|
|
|
|
|
|
|
|
constructor(embark, options) {
|
|
|
|
this.logger = embark.logger;
|
2018-04-30 15:56:43 +10:00
|
|
|
this.events = embark.events;
|
|
|
|
this.buildDir = options.buildDir;
|
2018-06-01 11:58:11 -04:00
|
|
|
this.storageConfig = embark.config.storageConfig;
|
|
|
|
this.host = options.host || this.storageConfig.host;
|
|
|
|
this.port = options.port || this.storageConfig.port;
|
2018-04-30 15:56:43 +10:00
|
|
|
this.embark = embark;
|
2018-06-01 11:58:11 -04:00
|
|
|
|
2018-07-08 00:46:15 +03:00
|
|
|
this.webServerConfig = embark.config.webServerConfig;
|
|
|
|
this.blockchainConfig = embark.config.blockchainConfig;
|
2018-07-07 19:29:04 +03:00
|
|
|
|
2018-06-01 13:12:17 +10:00
|
|
|
this.providerUrl = utils.buildUrl(options.protocol || options.storageConfig.upload.protocol, options.host || options.storageConfig.upload.host, options.port || options.storageConfig.upload.port);
|
2018-06-01 11:58:11 -04:00
|
|
|
|
2018-05-31 20:18:25 +10:00
|
|
|
this.getUrl = options.storageConfig.upload.getUrl || this.providerUrl + '/bzz:/';
|
2018-06-01 11:58:11 -04:00
|
|
|
|
2018-05-30 16:34:36 +10:00
|
|
|
this.bzz = new Web3Bzz(this.providerUrl);
|
2018-07-07 19:29:04 +03:00
|
|
|
|
|
|
|
this.commandlineDeploy();
|
|
|
|
this.setServiceCheck();
|
|
|
|
this.addProviderToEmbarkJS();
|
|
|
|
this.startProcess(() => {});
|
2018-07-07 20:56:34 +03:00
|
|
|
|
|
|
|
this._checkService((err) => {
|
|
|
|
if (!err) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
self.logger.info("Swarm node not found, attempting to start own node");
|
|
|
|
self.startProcess(() => {});
|
|
|
|
});
|
2018-05-25 17:13:57 +10:00
|
|
|
}
|
|
|
|
|
2018-04-30 15:56:43 +10:00
|
|
|
commandlineDeploy() {
|
2017-12-26 19:55:42 -05:00
|
|
|
this.upload_swarm = new UploadSwarm({
|
2018-04-30 15:56:43 +10:00
|
|
|
buildDir: this.buildDir || 'dist/',
|
|
|
|
storageConfig: this.storageConfig,
|
2018-05-30 16:34:36 +10:00
|
|
|
getUrl: this.getUrl,
|
2018-04-30 15:56:43 +10:00
|
|
|
bzz: this.bzz
|
2017-12-26 19:55:42 -05:00
|
|
|
});
|
|
|
|
|
2018-07-07 18:11:45 +03:00
|
|
|
this.events.setCommandHandler('storage:upload:swarm', this.upload_swarm.deploy.bind(this.upload_swarm));
|
2017-12-26 19:55:42 -05:00
|
|
|
}
|
|
|
|
|
2018-04-30 15:56:43 +10:00
|
|
|
setServiceCheck() {
|
|
|
|
let self = this;
|
|
|
|
|
|
|
|
let storageConfig = this.storageConfig;
|
|
|
|
|
|
|
|
if (!storageConfig.enabled) {
|
|
|
|
return;
|
|
|
|
}
|
2018-05-31 20:18:25 +10:00
|
|
|
if (_.findWhere(this.storageConfig.dappConnection, {'provider': 'swarm'}) === undefined && (storageConfig.upload.provider !== 'swarm' || storageConfig.available_providers.indexOf("swarm") < 0)) {
|
2018-04-30 15:56:43 +10:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.events.on('check:backOnline:Swarm', function () {
|
2018-05-08 17:49:46 -04:00
|
|
|
self.logger.info(__('Swarm node detected...'));
|
2018-04-30 15:56:43 +10:00
|
|
|
});
|
|
|
|
|
|
|
|
this.events.on('check:wentOffline:Swarm', function () {
|
2018-05-08 17:49:46 -04:00
|
|
|
self.logger.info(__('Swarm node is offline...'));
|
2018-04-30 15:56:43 +10:00
|
|
|
});
|
|
|
|
|
2018-06-01 11:58:11 -04:00
|
|
|
self.events.request("services:register", 'Swarm', function(cb){
|
2018-06-05 11:39:28 +10:00
|
|
|
self.logger.trace(`Checking Swarm availability on ${self.bzz.currentProvider}...`);
|
2018-07-07 20:56:34 +03:00
|
|
|
self._checkService((err, result) => {
|
|
|
|
if (err) {
|
|
|
|
self.logger.trace("Check Swarm availability error: " + err);
|
|
|
|
return cb({name: "Swarm ", status: 'off'});
|
|
|
|
}
|
|
|
|
self.logger.trace("Swarm " + (result ? '':'on') + "available");
|
2018-04-30 15:56:43 +10:00
|
|
|
return cb({name: "Swarm ", status: result ? 'on':'off'});
|
2018-07-07 20:56:34 +03:00
|
|
|
});
|
2018-04-30 15:56:43 +10:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-07-07 20:56:34 +03:00
|
|
|
_checkService(cb) {
|
|
|
|
this.bzz.isAvailable().then(result => {
|
|
|
|
cb(null, result);
|
|
|
|
}).catch(cb);
|
|
|
|
}
|
|
|
|
|
2018-05-28 22:59:18 +10:00
|
|
|
addProviderToEmbarkJS() {
|
2018-04-30 15:56:43 +10:00
|
|
|
// TODO: make this a shouldAdd condition
|
|
|
|
if (this.storageConfig === {}) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-05-31 20:18:25 +10:00
|
|
|
if (this.storageConfig.available_providers.indexOf('swarm') < 0 || _.findWhere(this.storageConfig.dappConnection, {'provider': 'swarm'}) === undefined || this.storageConfig.enabled !== true) {
|
2018-04-30 15:56:43 +10:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
let code = "";
|
|
|
|
code += "\n" + fs.readFileSync(utils.joinPath(__dirname, 'embarkjs.js')).toString();
|
|
|
|
code += "\nEmbarkJS.Storage.registerProvider('swarm', __embarkSwarm);";
|
|
|
|
|
|
|
|
this.embark.addCodeToEmbarkJS(code);
|
|
|
|
}
|
2018-07-07 19:29:04 +03:00
|
|
|
|
|
|
|
startProcess(callback) {
|
|
|
|
let self = this;
|
|
|
|
const storageProcessesLauncher = new StorageProcessesLauncher({
|
|
|
|
logger: self.logger,
|
|
|
|
events: self.events,
|
|
|
|
storageConfig: self.storageConfig,
|
|
|
|
webServerConfig: self.webServerConfig,
|
|
|
|
blockchainConfig: self.blockchainConfig
|
|
|
|
});
|
|
|
|
self.logger.trace(`Storage module: Launching swarm process...`);
|
|
|
|
return storageProcessesLauncher.launchProcess('swarm', (err) => {
|
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
callback();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-12-26 19:55:42 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = Swarm;
|
|
|
|
|