mirror of
https://github.com/status-im/embark-area-51.git
synced 2025-01-10 22:16:20 +00:00
Storage config improvements start. Adjusted the config and have started to support those improvements through the codebase.
Currently stuck on starting multiple storage servcies at once. Might need a change in storage config spec. WIP.
This commit is contained in:
parent
ac69f2f9fd
commit
f6667b6948
15
js/embark.js
15
js/embark.js
@ -230,7 +230,22 @@ EmbarkJS.Storage.setProvider = function(provider, options) {
|
|||||||
return providerObj.setProvider(options);
|
return providerObj.setProvider(options);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
EmbarkJS.Storage.setProviders = function(provider, dappConnOptions) {
|
||||||
|
let providerObj = this.Providers[provider];
|
||||||
|
|
||||||
|
if (!providerObj) {
|
||||||
|
throw new Error('Unknown storage provider');
|
||||||
|
}
|
||||||
|
|
||||||
|
this.currentStorage = providerObj;
|
||||||
|
|
||||||
|
return providerObj.setProviders(dappConnOptions);
|
||||||
|
};
|
||||||
|
|
||||||
EmbarkJS.Storage.isAvailable = function(){
|
EmbarkJS.Storage.isAvailable = function(){
|
||||||
|
if (!this.currentStorage) {
|
||||||
|
throw new Error('Storage provider not set; e.g EmbarkJS.Storage.setProvider("ipfs")');
|
||||||
|
}
|
||||||
return this.currentStorage.isAvailable();
|
return this.currentStorage.isAvailable();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -209,7 +209,7 @@ Config.prototype.loadExternalContractsFiles = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
Config.prototype.loadStorageConfigFile = function() {
|
Config.prototype.loadStorageConfigFile = function() {
|
||||||
var versions = utils.recursiveMerge({"ipfs-api": "17.2.4"}, this.embarkConfig.versions || {});
|
var versions = utils.recursiveMerge({"ipfs-api": "17.2.4", "p-iteration": "1.1.7"}, this.embarkConfig.versions || {});
|
||||||
|
|
||||||
var configObject = {
|
var configObject = {
|
||||||
"default": {
|
"default": {
|
||||||
@ -217,11 +217,13 @@ Config.prototype.loadStorageConfigFile = function() {
|
|||||||
"enabled": true,
|
"enabled": true,
|
||||||
"available_providers": ["ipfs", "swarm"],
|
"available_providers": ["ipfs", "swarm"],
|
||||||
"ipfs_bin": "ipfs",
|
"ipfs_bin": "ipfs",
|
||||||
"provider": "ipfs",
|
"upload": {
|
||||||
"protocol": "http",
|
"provider": "ipfs",
|
||||||
"host": "localhost",
|
"protocol": "http",
|
||||||
"port": 5001,
|
"host": "localhost",
|
||||||
"getUrl": "http://localhost:8080/ipfs/"
|
"port": 5001,
|
||||||
|
"getUrl": "http://localhost:8080/ipfs/"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -107,10 +107,9 @@ class Engine {
|
|||||||
"fileWatcher": this.fileWatchService,
|
"fileWatcher": this.fileWatchService,
|
||||||
"webServer": this.webServerService,
|
"webServer": this.webServerService,
|
||||||
"namingSystem": this.namingSystem,
|
"namingSystem": this.namingSystem,
|
||||||
"ipfs": this.ipfsService,
|
|
||||||
"web3": this.web3Service,
|
"web3": this.web3Service,
|
||||||
"libraryManager": this.libraryManagerService,
|
"libraryManager": this.libraryManagerService,
|
||||||
"swarm": this.swarmService
|
"storage": this.storageService
|
||||||
};
|
};
|
||||||
|
|
||||||
let service = services[serviceName];
|
let service = services[serviceName];
|
||||||
@ -135,8 +134,8 @@ class Engine {
|
|||||||
logger: this.logger,
|
logger: this.logger,
|
||||||
plugins: this.plugins
|
plugins: this.plugins
|
||||||
});
|
});
|
||||||
|
|
||||||
this.events.on('code-generator-ready', function () {
|
this.events.on('code-generator-ready', function () {
|
||||||
|
console.log('CODE GENERATOR READY EVENT FIRED');
|
||||||
self.events.request('code', function (abi, contractsJSON) {
|
self.events.request('code', function (abi, contractsJSON) {
|
||||||
pipeline.build(abi, contractsJSON, null, () => {
|
pipeline.build(abi, contractsJSON, null, () => {
|
||||||
if (self.watch) {
|
if (self.watch) {
|
||||||
@ -264,15 +263,12 @@ class Engine {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
ipfsService(_options) {
|
storageService(_options) {
|
||||||
this.registerModule('ipfs', {
|
this.registerModule('ipfs', {
|
||||||
addCheck: this.servicesMonitor.addCheck.bind(this.servicesMonitor),
|
addCheck: this.servicesMonitor.addCheck.bind(this.servicesMonitor),
|
||||||
host: _options.host,
|
host: _options.host,
|
||||||
port: _options.port
|
port: _options.port
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
swarmService(_options) {
|
|
||||||
this.registerModule('swarm', {
|
this.registerModule('swarm', {
|
||||||
addCheck: this.servicesMonitor.addCheck.bind(this.servicesMonitor),
|
addCheck: this.servicesMonitor.addCheck.bind(this.servicesMonitor),
|
||||||
// TODO: this should not be needed and should be deducted from the config instead
|
// TODO: this should not be needed and should be deducted from the config instead
|
||||||
|
@ -128,6 +128,12 @@
|
|||||||
"Error while downloading the file": "Error while downloading the file",
|
"Error while downloading the file": "Error while downloading the file",
|
||||||
"Error while loading the content of ": "Error while loading the content of ",
|
"Error while loading the content of ": "Error while loading the content of ",
|
||||||
"no contracts found": "no contracts found",
|
"no contracts found": "no contracts found",
|
||||||
|
"IPFS node is offline": "IPFS node is offline",
|
||||||
|
"IPFS node detected": "IPFS node detected",
|
||||||
|
"Webserver is offline": "Webserver is offline",
|
||||||
|
"DApp path length is too long: \"": "DApp path length is too long: \"",
|
||||||
|
"This is known to cause issues with some applications, please consider reducing your DApp path's length to 66 characters or less.": "This is known to cause issues with some applications, please consider reducing your DApp path's length to 66 characters or less."
|
||||||
|
"no contracts found": "no contracts found",
|
||||||
"DApp path length is too long: \"": "DApp path length is too long: \"",
|
"DApp path length is too long: \"": "DApp path length is too long: \"",
|
||||||
"This is known to cause issues with some applications, please consider reducing your DApp path's length to 66 characters or less.": "This is known to cause issues with some applications, please consider reducing your DApp path's length to 66 characters or less.",
|
"This is known to cause issues with some applications, please consider reducing your DApp path's length to 66 characters or less.": "This is known to cause issues with some applications, please consider reducing your DApp path's length to 66 characters or less.",
|
||||||
"DApp path length is too long: ": "DApp path length is too long: ",
|
"DApp path length is too long: ": "DApp path length is too long: ",
|
||||||
|
27
lib/index.js
27
lib/index.js
@ -159,11 +159,9 @@ class Embark {
|
|||||||
engine.startService("web3");
|
engine.startService("web3");
|
||||||
engine.startService("pipeline");
|
engine.startService("pipeline");
|
||||||
engine.startService("deployment");
|
engine.startService("deployment");
|
||||||
|
engine.startService('storage');
|
||||||
engine.startService("codeGenerator");
|
engine.startService("codeGenerator");
|
||||||
engine.startService("namingSystem");
|
engine.startService("namingSystem");
|
||||||
// TODO: this should be just 'storage' and the storage should figure out the module
|
|
||||||
engine.startService(engine.config.storageConfig.provider);
|
|
||||||
|
|
||||||
engine.events.on('check:backOnline:Ethereum', function () {
|
engine.events.on('check:backOnline:Ethereum', function () {
|
||||||
engine.logger.info(__('Ethereum node detected') + '..');
|
engine.logger.info(__('Ethereum node detected') + '..');
|
||||||
engine.config.reloadConfig();
|
engine.config.reloadConfig();
|
||||||
@ -249,10 +247,8 @@ class Embark {
|
|||||||
engine.startService("web3");
|
engine.startService("web3");
|
||||||
engine.startService("pipeline");
|
engine.startService("pipeline");
|
||||||
engine.startService("deployment", {onlyCompile: options.onlyCompile});
|
engine.startService("deployment", {onlyCompile: options.onlyCompile});
|
||||||
|
engine.startService("storage");
|
||||||
engine.startService("codeGenerator");
|
engine.startService("codeGenerator");
|
||||||
// TODO: this should be just 'storage' and the storage should figure out the modules to load
|
|
||||||
engine.startService("ipfs");
|
|
||||||
engine.startService("swarm");
|
|
||||||
callback();
|
callback();
|
||||||
},
|
},
|
||||||
function deploy(callback) {
|
function deploy(callback) {
|
||||||
@ -305,6 +301,7 @@ class Embark {
|
|||||||
engine.startService("libraryManager");
|
engine.startService("libraryManager");
|
||||||
engine.startService("pipeline");
|
engine.startService("pipeline");
|
||||||
engine.startService("deployment", {onlyCompile: true});
|
engine.startService("deployment", {onlyCompile: true});
|
||||||
|
|
||||||
engine.startService("codeGenerator");
|
engine.startService("codeGenerator");
|
||||||
|
|
||||||
engine.events.request('deploy:contracts', function(err) {
|
engine.events.request('deploy:contracts', function(err) {
|
||||||
@ -355,7 +352,7 @@ class Embark {
|
|||||||
});
|
});
|
||||||
engine.init();
|
engine.init();
|
||||||
|
|
||||||
let platform = engine.config.storageConfig.provider;
|
let platform = engine.config.storageConfig.upload.provider;
|
||||||
|
|
||||||
let cmdPlugin;
|
let cmdPlugin;
|
||||||
async.waterfall([
|
async.waterfall([
|
||||||
@ -367,9 +364,8 @@ class Embark {
|
|||||||
engine.startService("web3");
|
engine.startService("web3");
|
||||||
engine.startService("pipeline");
|
engine.startService("pipeline");
|
||||||
engine.startService("deployment");
|
engine.startService("deployment");
|
||||||
|
engine.startService('storage');
|
||||||
engine.startService("codeGenerator");
|
engine.startService("codeGenerator");
|
||||||
// TODO: this should be just 'storage' and the storage should figure out the modules to load
|
|
||||||
engine.startService(platform.toLowerCase());
|
|
||||||
engine.startMonitor();
|
engine.startMonitor();
|
||||||
callback();
|
callback();
|
||||||
},
|
},
|
||||||
@ -395,6 +391,16 @@ class Embark {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
if (!checkFn || typeof checkFn.fn !== 'function') {
|
||||||
|
return callback();
|
||||||
|
}
|
||||||
|
checkFn.fn(function (serviceCheckResult) {
|
||||||
|
if (!serviceCheckResult.status || serviceCheckResult.status === 'off') {
|
||||||
|
let config = engine.config.storageConfig.upload;
|
||||||
|
return callback({message: __('Cannot upload: {{platform}} node is not running on {{protocol}}://{{host}}:{{port}}.', {platform: platform, protocol: config.protocol, host: config.host, port: config.port})});
|
||||||
|
}
|
||||||
|
callback();
|
||||||
|
});
|
||||||
},
|
},
|
||||||
function setupStoragePlugin(callback){
|
function setupStoragePlugin(callback){
|
||||||
let pluginList = engine.plugins.listPlugins();
|
let pluginList = engine.plugins.listPlugins();
|
||||||
@ -413,8 +419,7 @@ class Embark {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
if (!cmdPlugin) {
|
if (!cmdPlugin) {
|
||||||
engine.logger.info(__('try "{{ipfs}}" or "{{swarm}}"', {ipfs: 'embark upload ipfs', swarm: 'embark upload swarm'}).green);
|
return callback({message: __('platform "{{platform}}" is specified as the upload provider, however no plugins have registered an upload command for "{{platform}}".', {platform: platform})});
|
||||||
return callback({message: 'unknown platform: ' + platform});
|
|
||||||
}
|
}
|
||||||
callback();
|
callback();
|
||||||
},
|
},
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import IpfsApi from 'ipfs-api';
|
import IpfsApi from 'ipfs-api';
|
||||||
|
//import {some} from 'p-iteration';
|
||||||
|
|
||||||
let __embarkIPFS = {};
|
let __embarkIPFS = {};
|
||||||
|
|
||||||
@ -10,7 +11,7 @@ __embarkIPFS.setProvider = function (options) {
|
|||||||
self.ipfsConnection = IpfsApi('localhost', '5001');
|
self.ipfsConnection = IpfsApi('localhost', '5001');
|
||||||
self._getUrl = "http://localhost:8080/ipfs/";
|
self._getUrl = "http://localhost:8080/ipfs/";
|
||||||
} else {
|
} else {
|
||||||
var ipfsOptions = {host: options.server, protocol: 'http'};
|
var ipfsOptions = {host: options.host || options.server, protocol: 'http'};
|
||||||
if (options.protocol) {
|
if (options.protocol) {
|
||||||
ipfsOptions.protocol = options.protocol;
|
ipfsOptions.protocol = options.protocol;
|
||||||
}
|
}
|
||||||
@ -22,7 +23,7 @@ __embarkIPFS.setProvider = function (options) {
|
|||||||
}
|
}
|
||||||
resolve(self);
|
resolve(self);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
console.log(err);
|
console.error(err);
|
||||||
self.ipfsConnection = null;
|
self.ipfsConnection = null;
|
||||||
reject(new Error('Failed to connect to IPFS'));
|
reject(new Error('Failed to connect to IPFS'));
|
||||||
}
|
}
|
||||||
@ -30,6 +31,29 @@ __embarkIPFS.setProvider = function (options) {
|
|||||||
return promise;
|
return promise;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
__embarkIPFS.setProviders = async function (dappConnOptions) {
|
||||||
|
var self = this;
|
||||||
|
try {
|
||||||
|
let workingConnFound = await some(dappConnOptions, async (dappConn) => {
|
||||||
|
if(dappConn === '$BZZ' || dappConn.provider !== 'ipfs') return false; // swarm has no bearing for ipfs plugin, continue
|
||||||
|
else {
|
||||||
|
// set the provider then check the connection, if true, use that provider, else, check next provider
|
||||||
|
try{
|
||||||
|
await self.setProvider(dappConn);
|
||||||
|
return await self.isAvailable();
|
||||||
|
} catch(err) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if(!workingConnFound) throw new Error('Could not connect to IPFS using any of the dappConnections in the storage config');
|
||||||
|
else return self;
|
||||||
|
} catch (err) {
|
||||||
|
self.ipfsConnection = null;
|
||||||
|
throw new Error('Failed to connect to IPFS: ' + err.message);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
__embarkIPFS.saveText = function (text) {
|
__embarkIPFS.saveText = function (text) {
|
||||||
const self = this;
|
const self = this;
|
||||||
var promise = new Promise(function (resolve, reject) {
|
var promise = new Promise(function (resolve, reject) {
|
||||||
@ -119,3 +143,4 @@ __embarkIPFS.getUrl = function (hash) {
|
|||||||
return (this._getUrl || "http://localhost:8080/ipfs/") + hash;
|
return (this._getUrl || "http://localhost:8080/ipfs/") + hash;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ let UploadIPFS = require('./upload.js');
|
|||||||
let utils = require('../../utils/utils.js');
|
let utils = require('../../utils/utils.js');
|
||||||
let fs = require('../../core/fs.js');
|
let fs = require('../../core/fs.js');
|
||||||
let IpfsApi = require('ipfs-api');
|
let IpfsApi = require('ipfs-api');
|
||||||
|
const _ = require('underscore');
|
||||||
|
|
||||||
class IPFS {
|
class IPFS {
|
||||||
|
|
||||||
@ -9,9 +10,10 @@ class IPFS {
|
|||||||
this.logger = embark.logger;
|
this.logger = embark.logger;
|
||||||
this.events = embark.events;
|
this.events = embark.events;
|
||||||
this.buildDir = options.buildDir;
|
this.buildDir = options.buildDir;
|
||||||
this.storageConfig = embark.config.storageConfig;
|
this.storageConfig = options.storageConfig;
|
||||||
this.host = options.host || this.storageConfig.host;
|
this.host = options.host || this.storageConfig.upload.host;
|
||||||
this.port = options.port || this.storageConfig.port;
|
this.port = options.port || this.storageConfig.upload.port;
|
||||||
|
this.protocol = options.protocol || this.storageConfig.upload.protocol;
|
||||||
this.addCheck = options.addCheck;
|
this.addCheck = options.addCheck;
|
||||||
this.embark = embark;
|
this.embark = embark;
|
||||||
|
|
||||||
@ -40,7 +42,7 @@ class IPFS {
|
|||||||
if (!storageConfig.enabled) {
|
if (!storageConfig.enabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (storageConfig.provider !== 'ipfs' && storageConfig.available_providers.indexOf("ipfs") < 0) {
|
if (storageConfig.upload.provider !== 'ipfs' || storageConfig.available_providers.indexOf("ipfs") < 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -58,7 +60,13 @@ class IPFS {
|
|||||||
|
|
||||||
self.addCheck('IPFS', function (cb) {
|
self.addCheck('IPFS', function (cb) {
|
||||||
self.logger.trace("Checking IPFS version...");
|
self.logger.trace("Checking IPFS version...");
|
||||||
utils.httpGetJson('http://' + self.host + ':' + self.port + '/api/v0/version', function (err, body) {
|
let url = (self.protocol || 'http') + '://' + self.host + ':' + self.port + '/api/v0/version';
|
||||||
|
if(self.protocol !== 'https'){
|
||||||
|
utils.httpGetJson(url, versionCb);
|
||||||
|
} else {
|
||||||
|
utils.httpsGetJson(url, versionCb);
|
||||||
|
}
|
||||||
|
function versionCb(err, body) {
|
||||||
if (err) {
|
if (err) {
|
||||||
self.logger.trace("Check IPFS version error: " + err);
|
self.logger.trace("Check IPFS version error: " + err);
|
||||||
return cb({name: "IPFS ", status: 'off'});
|
return cb({name: "IPFS ", status: 'off'});
|
||||||
@ -67,7 +75,7 @@ class IPFS {
|
|||||||
return cb({name: ("IPFS " + body.Version), status: 'on'});
|
return cb({name: ("IPFS " + body.Version), status: 'on'});
|
||||||
}
|
}
|
||||||
return cb({name: "IPFS ", status: 'on'});
|
return cb({name: "IPFS ", status: 'on'});
|
||||||
});
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,7 +86,7 @@ class IPFS {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((this.storageConfig.available_providers.indexOf('ipfs') < 0) && (this.storageConfig.provider !== 'ipfs' || this.storageConfig.enabled !== true)) {
|
if (this.storageConfig.available_providers.indexOf('ipfs') < 0 || _.findWhere(this.storageConfig.dappConnection, {'provider': 'ipfs'}) === undefined || this.storageConfig.enabled !== true) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -91,6 +99,15 @@ class IPFS {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
self.events.request("version:get:p-iteration", function(pIterationVersion) {
|
||||||
|
let currentPIterationVersion = require('../../../package.json').dependencies["p-iteration"];
|
||||||
|
if (pIterationVersion !== currentPIterationVersion) {
|
||||||
|
self.events.request("version:getPackageLocation", "p-iteration", pIterationVersion, function(err, location) {
|
||||||
|
self.embark.registerImportFile("p-iteration", fs.dappPath(location));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
let code = "";
|
let code = "";
|
||||||
code += "\n" + fs.readFileSync(utils.joinPath(__dirname, 'embarkjs.js')).toString();
|
code += "\n" + fs.readFileSync(utils.joinPath(__dirname, 'embarkjs.js')).toString();
|
||||||
code += "\nEmbarkJS.Storage.registerProvider('ipfs', __embarkIPFS);";
|
code += "\nEmbarkJS.Storage.registerProvider('ipfs', __embarkIPFS);";
|
||||||
@ -99,16 +116,10 @@ class IPFS {
|
|||||||
}
|
}
|
||||||
|
|
||||||
addSetProvider() {
|
addSetProvider() {
|
||||||
let config = JSON.stringify({
|
let code = "\nEmbarkJS.Storage.setProviders('ipfs'," + JSON.stringify(this.storageConfig.dappConnection) + ");";
|
||||||
server: this.storageConfig.host,
|
|
||||||
port: this.storageConfig.port,
|
|
||||||
protocol: this.storageConfig.protocol,
|
|
||||||
getUrl: this.storageConfig.getUrl
|
|
||||||
});
|
|
||||||
let code = "\nEmbarkJS.Storage.setProvider('ipfs'," + config + ");";
|
|
||||||
|
|
||||||
let shouldInit = (storageConfig) => {
|
let shouldInit = (storageConfig) => {
|
||||||
return (storageConfig.provider === 'ipfs' && storageConfig.enabled === true);
|
return (this.storageConfig.dappConnection !== undefined && this.storageConfig.dappConnection.some((dappConn) => dappConn.provider === 'ipfs') && storageConfig.enabled === true);
|
||||||
};
|
};
|
||||||
|
|
||||||
this.embark.addProviderInit('storage', code, shouldInit);
|
this.embark.addProviderInit('storage', code, shouldInit);
|
||||||
|
@ -1,20 +1,19 @@
|
|||||||
/*global web3 */
|
/*global web3 */
|
||||||
let __embarkSwarm = {};
|
let __embarkSwarm = {};
|
||||||
const bytes = require("eth-lib/lib/bytes");
|
const bytes = require("eth-lib/lib/bytes");
|
||||||
|
import {some} from 'p-iteration';
|
||||||
|
|
||||||
__embarkSwarm.setProvider = function (options) {
|
__embarkSwarm.setProvider = function (options) {
|
||||||
this.bzz = web3.bzz;
|
this.bzz = web3.bzz;
|
||||||
this.protocol = options.protocol;
|
this.protocol = options.protocol || 'http';
|
||||||
this.host = options.host;
|
this.connectUrl = `${this.protocol}://${options.host}:${options.port}`;
|
||||||
this.port = options.port;
|
|
||||||
this.connectUrl = `${options.protocol}://${options.host}:${options.port}`;
|
|
||||||
this.connectError = new Error(`Cannot connect to Swarm node on ${this.connectUrl}`);
|
this.connectError = new Error(`Cannot connect to Swarm node on ${this.connectUrl}`);
|
||||||
this._getUrl = options.getUrl || `${this.connectUrl}/bzzr:/`;
|
//this._getUrl = options.getUrl || `${this.connectUrl}/bzzr:/`;
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
try {
|
try {
|
||||||
if (!this.bzz.currentProvider) {
|
if (!this.bzz.currentProvider) {
|
||||||
this.bzz.setProvider(`${options.protocol}://${options.host}:${options.port}`);
|
this.bzz.setProvider(this.connectUrl);
|
||||||
}
|
}
|
||||||
resolve(this);
|
resolve(this);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@ -24,6 +23,28 @@ __embarkSwarm.setProvider = function (options) {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
__embarkSwarm.setProviders = async function (dappConnOptions) {
|
||||||
|
var self = this;
|
||||||
|
try {
|
||||||
|
let workingConnFound = await some(dappConnOptions, async (dappConn) => {
|
||||||
|
if(dappConn === '$BZZ'){
|
||||||
|
return self.isAvailable();
|
||||||
|
}
|
||||||
|
else if(dappConn.provider === 'swarm')
|
||||||
|
{
|
||||||
|
// set the provider then check the connection, if true, use that provider, else, check next provider
|
||||||
|
await self.setProvider(dappConn);
|
||||||
|
return self.isAvailable();
|
||||||
|
}
|
||||||
|
else return false;
|
||||||
|
});
|
||||||
|
if(!workingConnFound) throw new Error('Could not connect to Swarm using any of the dappConnections in the storage config');
|
||||||
|
else return self;
|
||||||
|
} catch (err) {
|
||||||
|
throw new Error('Failed to connect to Swarm: ' + err.message);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
__embarkSwarm.isAvailable = function () {
|
__embarkSwarm.isAvailable = function () {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
if (!this.bzz) {
|
if (!this.bzz) {
|
||||||
|
@ -8,9 +8,10 @@ class Swarm {
|
|||||||
this.logger = embark.logger;
|
this.logger = embark.logger;
|
||||||
this.events = embark.events;
|
this.events = embark.events;
|
||||||
this.buildDir = options.buildDir;
|
this.buildDir = options.buildDir;
|
||||||
this.storageConfig = embark.config.storageConfig;
|
this.storageConfig = options.storageConfig;
|
||||||
this.host = options.host || this.storageConfig.host;
|
this.host = options.host || options.storageConfig.upload.host;
|
||||||
this.port = options.port || this.storageConfig.port;
|
this.port = options.port || options.storageConfig.upload.port;
|
||||||
|
this.protocol = options.protocol || options.storageConfig.upload.protocol;
|
||||||
this.addCheck = options.addCheck;
|
this.addCheck = options.addCheck;
|
||||||
this.embark = embark;
|
this.embark = embark;
|
||||||
this.bzz = options.bzz;
|
this.bzz = options.bzz;
|
||||||
@ -24,7 +25,7 @@ class Swarm {
|
|||||||
|
|
||||||
initSwarmProvider(){
|
initSwarmProvider(){
|
||||||
if(!this.bzz.currentProvider) {
|
if(!this.bzz.currentProvider) {
|
||||||
this.bzz.setProvider(`http://${this.host}:${this.port}`);
|
this.bzz.setProvider(`${this.protocol}://${this.host}:${this.port}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,7 +48,7 @@ class Swarm {
|
|||||||
if (!storageConfig.enabled) {
|
if (!storageConfig.enabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (storageConfig.provider !== 'swarm' && storageConfig.available_providers.indexOf("swarm") < 0) {
|
if (storageConfig.upload.provider !== 'swarm' || storageConfig.available_providers.indexOf("swarm") < 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,15 +77,25 @@ class Swarm {
|
|||||||
}
|
}
|
||||||
|
|
||||||
addSwarmToEmbarkJS() {
|
addSwarmToEmbarkJS() {
|
||||||
|
let self = this;
|
||||||
// TODO: make this a shouldAdd condition
|
// TODO: make this a shouldAdd condition
|
||||||
if (this.storageConfig === {}) {
|
if (this.storageConfig === {}) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((this.storageConfig.available_providers.indexOf('swarm') < 0) && (this.storageConfig.provider !== 'swarm' || this.storageConfig.enabled !== true)) {
|
if (this.storageConfig.available_providers.indexOf('swarm') < 0 || this.storageConfig.enabled !== true) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.events.request("version:get:p-iteration", function(pIterationVersion) {
|
||||||
|
let currentPIterationVersion = require('../../../package.json').dependencies["p-iteration"];
|
||||||
|
if (pIterationVersion !== currentPIterationVersion) {
|
||||||
|
self.events.request("version:getPackageLocation", "p-iteration", pIterationVersion, function(err, location) {
|
||||||
|
self.embark.registerImportFile("p-iteration", fs.dappPath(location));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
let code = "";
|
let code = "";
|
||||||
code += "\n" + fs.readFileSync(utils.joinPath(__dirname, 'embarkjs.js')).toString();
|
code += "\n" + fs.readFileSync(utils.joinPath(__dirname, 'embarkjs.js')).toString();
|
||||||
code += "\nEmbarkJS.Storage.registerProvider('swarm', __embarkSwarm);";
|
code += "\nEmbarkJS.Storage.registerProvider('swarm', __embarkSwarm);";
|
||||||
@ -93,16 +104,10 @@ class Swarm {
|
|||||||
}
|
}
|
||||||
|
|
||||||
addSetProvider() {
|
addSetProvider() {
|
||||||
let config = JSON.stringify({
|
let code = "\nEmbarkJS.Storage.setProviders('swarm'," + JSON.stringify(this.storageConfig.dappConnection) + ");";
|
||||||
host: this.storageConfig.host,
|
|
||||||
port: this.storageConfig.port,
|
|
||||||
protocol: this.storageConfig.protocol,
|
|
||||||
getUrl: this.storageConfig.getUrl
|
|
||||||
});
|
|
||||||
let code = "\nEmbarkJS.Storage.setProvider('swarm'," + config + ");";
|
|
||||||
|
|
||||||
let shouldInit = (storageConfig) => {
|
let shouldInit = (storageConfig) => {
|
||||||
return (storageConfig.provider === 'swarm' && storageConfig.enabled === true);
|
return (this.storageConfig.dappConnection !== undefined && this.storageConfig.dappConnection.some((dappConn) => dappConn.provider === 'swarm') && storageConfig.enabled === true);
|
||||||
};
|
};
|
||||||
|
|
||||||
this.embark.addProviderInit('storage', code, shouldInit);
|
this.embark.addProviderInit('storage', code, shouldInit);
|
||||||
|
@ -69,6 +69,17 @@ function httpGetJson(url, callback) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function httpsGetJson(url, callback) {
|
||||||
|
httpGetRequest(https, url, function(err, body) {
|
||||||
|
try {
|
||||||
|
let parsed = JSON.parse(body);
|
||||||
|
return callback(err, parsed);
|
||||||
|
} catch(e) {
|
||||||
|
return callback(e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
function runCmd(cmd, options) {
|
function runCmd(cmd, options) {
|
||||||
let result = shelljs.exec(cmd, options || {silent: true});
|
let result = shelljs.exec(cmd, options || {silent: true});
|
||||||
if (result.code !== 0) {
|
if (result.code !== 0) {
|
||||||
@ -208,6 +219,7 @@ module.exports = {
|
|||||||
httpGet: httpGet,
|
httpGet: httpGet,
|
||||||
httpsGet: httpsGet,
|
httpsGet: httpsGet,
|
||||||
httpGetJson: httpGetJson,
|
httpGetJson: httpGetJson,
|
||||||
|
httpsGetJson: httpsGetJson,
|
||||||
runCmd: runCmd,
|
runCmd: runCmd,
|
||||||
cd: cd,
|
cd: cd,
|
||||||
sed: sed,
|
sed: sed,
|
||||||
|
@ -23,15 +23,17 @@ class LibraryManager {
|
|||||||
let solcVersionInConfig = this.contractsConfig.versions.solc;
|
let solcVersionInConfig = this.contractsConfig.versions.solc;
|
||||||
let web3VersionInConfig = this.contractsConfig.versions["web3"];
|
let web3VersionInConfig = this.contractsConfig.versions["web3"];
|
||||||
let ipfsApiVersion = this.storageConfig.versions["ipfs-api"];
|
let ipfsApiVersion = this.storageConfig.versions["ipfs-api"];
|
||||||
|
let pIterationVersion = this.storageConfig.versions["p-iteration"];
|
||||||
|
|
||||||
this.versions['solc'] = solcVersionInConfig;
|
this.versions['solc'] = solcVersionInConfig;
|
||||||
this.versions['web3'] = web3VersionInConfig;
|
this.versions['web3'] = web3VersionInConfig;
|
||||||
this.versions['ipfs-api'] = ipfsApiVersion;
|
this.versions['ipfs-api'] = ipfsApiVersion;
|
||||||
|
this.versions['p-iteration'] = pIterationVersion;
|
||||||
|
|
||||||
Object.keys(this.versions).forEach(versionKey => {
|
Object.keys(this.versions).forEach(versionKey => {
|
||||||
const newVersion = this.versions[versionKey].trim();
|
const newVersion = this.versions[versionKey].trim();
|
||||||
if (newVersion !== this.versions[versionKey]) {
|
if (newVersion !== this.versions[versionKey]) {
|
||||||
this.embark.logger.warn(__('There a a space in the version of {{versionKey}}. We corrected it for you ({{correction}}).', {versionKey: versionKey, correction: `"${this.versions[versionKey]}" => "${newVersion}"`}));
|
this.embark.logger.warn(__('There is a space in the version of {{versionKey}}. We corrected it for you ({{correction}}).', {versionKey: versionKey, correction: `"${this.versions[versionKey]}" => "${newVersion}"`}));
|
||||||
this.versions[versionKey] = newVersion;
|
this.versions[versionKey] = newVersion;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
33
package-lock.json
generated
33
package-lock.json
generated
@ -1637,7 +1637,7 @@
|
|||||||
"browserify-zlib": {
|
"browserify-zlib": {
|
||||||
"version": "0.2.0",
|
"version": "0.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz",
|
||||||
"integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==",
|
"integrity": "sha1-KGlFnZqjviRf6P4sofRuLn9U1z8=",
|
||||||
"requires": {
|
"requires": {
|
||||||
"pako": "1.0.6"
|
"pako": "1.0.6"
|
||||||
}
|
}
|
||||||
@ -2806,7 +2806,7 @@
|
|||||||
"domain-browser": {
|
"domain-browser": {
|
||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz",
|
||||||
"integrity": "sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA=="
|
"integrity": "sha1-PTH1AZGmdJ3RN1p/Ui6CPULlTto="
|
||||||
},
|
},
|
||||||
"drbg.js": {
|
"drbg.js": {
|
||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
@ -2922,7 +2922,7 @@
|
|||||||
"errno": {
|
"errno": {
|
||||||
"version": "0.1.7",
|
"version": "0.1.7",
|
||||||
"resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz",
|
"resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz",
|
||||||
"integrity": "sha512-MfrRBDWzIWifgq6tJj60gkAwtLNb6sQPlcFrSOflcP1aFmmruKQ2wRnze/8V6kgyz7H3FF8Npzv78mZ7XLLflg==",
|
"integrity": "sha1-RoTXF3mtOa8Xfj8AeZb3xnyFJhg=",
|
||||||
"requires": {
|
"requires": {
|
||||||
"prr": "1.0.1"
|
"prr": "1.0.1"
|
||||||
}
|
}
|
||||||
@ -3594,6 +3594,7 @@
|
|||||||
"integrity": "sha1-eguHvzZw+S9gf5j6aniAHZdBsSQ=",
|
"integrity": "sha1-eguHvzZw+S9gf5j6aniAHZdBsSQ=",
|
||||||
"requires": {
|
"requires": {
|
||||||
"webpack": "3.11.0"
|
"webpack": "3.11.0"
|
||||||
|
<<<<<<< develop
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"has-flag": {
|
"has-flag": {
|
||||||
@ -3638,6 +3639,8 @@
|
|||||||
"yargs": "8.0.2"
|
"yargs": "8.0.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
=======
|
||||||
|
>>>>>>> Storage config improvements start. Adjusted the config and have started to support those improvements through the codebase.
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"ethereumjs-tx": {
|
"ethereumjs-tx": {
|
||||||
@ -6229,7 +6232,7 @@
|
|||||||
"json-loader": {
|
"json-loader": {
|
||||||
"version": "0.5.7",
|
"version": "0.5.7",
|
||||||
"resolved": "https://registry.npmjs.org/json-loader/-/json-loader-0.5.7.tgz",
|
"resolved": "https://registry.npmjs.org/json-loader/-/json-loader-0.5.7.tgz",
|
||||||
"integrity": "sha512-QLPs8Dj7lnf3e3QYS1zkCo+4ZwqOiF9d/nZnYozTISxXWCfNs9yuky5rJw4/W34s7POaNlbZmQGaB5NiXCbP4w=="
|
"integrity": "sha1-3KFKcCNf+C8KyaOr62DTN6NlGF0="
|
||||||
},
|
},
|
||||||
"json-parse-better-errors": {
|
"json-parse-better-errors": {
|
||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
@ -6667,11 +6670,14 @@
|
|||||||
"yallist": "3.0.2"
|
"yallist": "3.0.2"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
<<<<<<< develop
|
||||||
"safe-buffer": {
|
"safe-buffer": {
|
||||||
"version": "5.1.2",
|
"version": "5.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
|
||||||
"integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
|
"integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
|
||||||
},
|
},
|
||||||
|
=======
|
||||||
|
>>>>>>> Storage config improvements start. Adjusted the config and have started to support those improvements through the codebase.
|
||||||
"tar": {
|
"tar": {
|
||||||
"version": "4.4.4",
|
"version": "4.4.4",
|
||||||
"resolved": "https://registry.npmjs.org/tar/-/tar-4.4.4.tgz",
|
"resolved": "https://registry.npmjs.org/tar/-/tar-4.4.4.tgz",
|
||||||
@ -7736,7 +7742,7 @@
|
|||||||
"node-libs-browser": {
|
"node-libs-browser": {
|
||||||
"version": "2.1.0",
|
"version": "2.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.1.0.tgz",
|
||||||
"integrity": "sha512-5AzFzdoIMb89hBGMZglEegffzgRg+ZFoUmisQ8HI4j1KDdpx13J0taNp2y9xPbur6W61gepGDDotGBVQ7mfUCg==",
|
"integrity": "sha1-X5QmPUBPbkR2fXJpAf/wVHjWAN8=",
|
||||||
"requires": {
|
"requires": {
|
||||||
"assert": "1.4.1",
|
"assert": "1.4.1",
|
||||||
"browserify-zlib": "0.2.0",
|
"browserify-zlib": "0.2.0",
|
||||||
@ -8174,7 +8180,7 @@
|
|||||||
"os-locale": {
|
"os-locale": {
|
||||||
"version": "2.1.0",
|
"version": "2.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/os-locale/-/os-locale-2.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/os-locale/-/os-locale-2.1.0.tgz",
|
||||||
"integrity": "sha512-3sslG3zJbEYcaC4YVAvDorjGxc7tv6KVATnLPZONiljsUncvihe9BQoVCEs0RZ1kmf4Hk9OBqlZfJZWI4GanKA==",
|
"integrity": "sha1-QrwpAKa1uL0XN2yOiCtlr8zyS/I=",
|
||||||
"requires": {
|
"requires": {
|
||||||
"execa": "0.7.0",
|
"execa": "0.7.0",
|
||||||
"lcid": "1.0.0",
|
"lcid": "1.0.0",
|
||||||
@ -8196,6 +8202,11 @@
|
|||||||
"resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
|
||||||
"integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4="
|
"integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4="
|
||||||
},
|
},
|
||||||
|
"p-iteration": {
|
||||||
|
"version": "1.1.7",
|
||||||
|
"resolved": "https://registry.npmjs.org/p-iteration/-/p-iteration-1.1.7.tgz",
|
||||||
|
"integrity": "sha512-VsYvUPjm2edbKkX4QzlASC1qB2e4Z6IE9WPaRVHKwCtobmB6vfUcU9eBOwj1k5uMNi8O6w89QfsDatO5ePSjQg=="
|
||||||
|
},
|
||||||
"p-limit": {
|
"p-limit": {
|
||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.2.0.tgz",
|
||||||
@ -8238,7 +8249,7 @@
|
|||||||
"pako": {
|
"pako": {
|
||||||
"version": "1.0.6",
|
"version": "1.0.6",
|
||||||
"resolved": "https://registry.npmjs.org/pako/-/pako-1.0.6.tgz",
|
"resolved": "https://registry.npmjs.org/pako/-/pako-1.0.6.tgz",
|
||||||
"integrity": "sha512-lQe48YPsMJAig+yngZ87Lus+NF+3mtu7DVOBu6b/gHO1YpKwIj5AWjZ/TOS7i46HD/UixzWb1zeWDZfGZ3iYcg=="
|
"integrity": "sha1-AQEhG6pwxLykoPY/Igbpe3368lg="
|
||||||
},
|
},
|
||||||
"parse-asn1": {
|
"parse-asn1": {
|
||||||
"version": "5.1.0",
|
"version": "5.1.0",
|
||||||
@ -12042,7 +12053,11 @@
|
|||||||
"webpack": {
|
"webpack": {
|
||||||
"version": "3.11.0",
|
"version": "3.11.0",
|
||||||
"resolved": "https://registry.npmjs.org/webpack/-/webpack-3.11.0.tgz",
|
"resolved": "https://registry.npmjs.org/webpack/-/webpack-3.11.0.tgz",
|
||||||
|
<<<<<<< develop
|
||||||
"integrity": "sha512-3kOFejWqj5ISpJk4Qj/V7w98h9Vl52wak3CLiw/cDOfbVTq7FeoZ0SdoHHY9PYlHr50ZS42OfvzE2vB4nncKQg==",
|
"integrity": "sha512-3kOFejWqj5ISpJk4Qj/V7w98h9Vl52wak3CLiw/cDOfbVTq7FeoZ0SdoHHY9PYlHr50ZS42OfvzE2vB4nncKQg==",
|
||||||
|
=======
|
||||||
|
"integrity": "sha1-d9pFGx17SxF62vQaGpO1dC8k2JQ=",
|
||||||
|
>>>>>>> Storage config improvements start. Adjusted the config and have started to support those improvements through the codebase.
|
||||||
"requires": {
|
"requires": {
|
||||||
"acorn": "5.5.3",
|
"acorn": "5.5.3",
|
||||||
"acorn-dynamic-import": "2.0.2",
|
"acorn-dynamic-import": "2.0.2",
|
||||||
@ -12110,7 +12125,7 @@
|
|||||||
"webpack-sources": {
|
"webpack-sources": {
|
||||||
"version": "1.1.0",
|
"version": "1.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.1.0.tgz",
|
||||||
"integrity": "sha512-aqYp18kPphgoO5c/+NaUvEeACtZjMESmDChuD3NBciVpah3XpMEU9VAAtIaB1BsfJWWTSdv8Vv1m3T0aRk2dUw==",
|
"integrity": "sha1-oQHrrlnWUHNU1x2AE5UKOot6WlQ=",
|
||||||
"requires": {
|
"requires": {
|
||||||
"source-list-map": "2.0.0",
|
"source-list-map": "2.0.0",
|
||||||
"source-map": "0.6.1"
|
"source-map": "0.6.1"
|
||||||
@ -12119,7 +12134,7 @@
|
|||||||
"source-map": {
|
"source-map": {
|
||||||
"version": "0.6.1",
|
"version": "0.6.1",
|
||||||
"resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
|
"resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
|
||||||
"integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g=="
|
"integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM="
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -55,6 +55,7 @@
|
|||||||
"merge": "^1.2.0",
|
"merge": "^1.2.0",
|
||||||
"orbit-db": "^0.17.3",
|
"orbit-db": "^0.17.3",
|
||||||
"os-locale": "^2.1.0",
|
"os-locale": "^2.1.0",
|
||||||
|
"p-iteration": "^1.1.7",
|
||||||
"parse-json": "^4.0.0",
|
"parse-json": "^4.0.0",
|
||||||
"promptly": "^2.1.0",
|
"promptly": "^2.1.0",
|
||||||
"propose": "0.0.5",
|
"propose": "0.0.5",
|
||||||
|
@ -11,7 +11,8 @@
|
|||||||
"versions": {
|
"versions": {
|
||||||
"web3": "1.0.0-beta",
|
"web3": "1.0.0-beta",
|
||||||
"solc": "0.4.23",
|
"solc": "0.4.23",
|
||||||
"ipfs-api": "17.2.4"
|
"ipfs-api": "17.2.4",
|
||||||
|
"p-iteration": "1.1.7"
|
||||||
},
|
},
|
||||||
"plugins": {}
|
"plugins": {}
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,8 @@
|
|||||||
"versions": {
|
"versions": {
|
||||||
"web3": "1.0.0-beta",
|
"web3": "1.0.0-beta",
|
||||||
"solc": "0.4.23",
|
"solc": "0.4.23",
|
||||||
"ipfs-api": "17.2.4"
|
"ipfs-api": "17.2.4",
|
||||||
|
"p-iteration": "1.1.7"
|
||||||
},
|
},
|
||||||
"plugins": {
|
"plugins": {
|
||||||
}
|
}
|
||||||
|
@ -1,25 +1,39 @@
|
|||||||
{
|
{
|
||||||
"default": {
|
"default": {
|
||||||
"enabled": true,
|
"enabled": true,
|
||||||
"available_providers": ["ipfs", "swarm"],
|
|
||||||
"ipfs_bin": "ipfs",
|
"ipfs_bin": "ipfs",
|
||||||
"provider": "ipfs",
|
|
||||||
"host": "localhost",
|
"available_providers": ["ipfs", "swarm"],
|
||||||
"port": 5001
|
|
||||||
|
"upload": {
|
||||||
|
"provider": "ipfs",
|
||||||
|
"host": "localhost",
|
||||||
|
"port": 5001
|
||||||
|
},
|
||||||
|
|
||||||
|
"dappConnection": [
|
||||||
|
"$BZZ",
|
||||||
|
{"provider": "swarm", "host": "localhost", "port": 8500, "getUrl": "http://localhost:8500/bzzr:/"},
|
||||||
|
{"provider": "ipfs", "host": "localhost", "port": 5001, "getUrl": "http://localhost:8080/ipfs/"}
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"development": {
|
"development": {
|
||||||
"enabled": true,
|
"enabled": true,
|
||||||
"provider": "swarm",
|
"upload": {
|
||||||
"host": "swarm-gateways.net",
|
"provider": "ipfs",
|
||||||
"port": false,
|
"host": "localhost",
|
||||||
"getUrl": "http://swarm-gateways.net/bzzr:/"
|
"port": 5001,
|
||||||
|
"getUrl": "http://localhost:8080/ipfs/"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"livenet": {
|
"livenet": {
|
||||||
"enabled": true,
|
"enabled": true,
|
||||||
"provider": "ipfs",
|
"upload":{
|
||||||
"host": "ipfs.infura.io",
|
"provider": "ipfs",
|
||||||
"protocol": "https",
|
"host": "ipfs.infura.io",
|
||||||
"port": false,
|
"protocol": "https",
|
||||||
"getUrl": "https://ipfs.infura.io/ipfs/"
|
"port": false,
|
||||||
|
"getUrl": "https://ipfs.infura.io/ipfs/"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -17,7 +17,8 @@
|
|||||||
"versions": {
|
"versions": {
|
||||||
"solc": "0.4.18",
|
"solc": "0.4.18",
|
||||||
"web3": "1.0.0-beta.34",
|
"web3": "1.0.0-beta.34",
|
||||||
"ipfs-api": "17.2.7"
|
"ipfs-api": "17.2.7",
|
||||||
|
"p-iteration": "1.1.7"
|
||||||
},
|
},
|
||||||
"plugins": {
|
"plugins": {
|
||||||
"embark-service": {}
|
"embark-service": {}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user