revert some of the recent changes

This commit is contained in:
Iuri Matias 2017-03-31 07:39:33 -04:00
parent faf0e1ff48
commit f4dbeb4b7e
1 changed files with 102 additions and 127 deletions

View File

@ -1,11 +1,10 @@
let fs = require('./fs.js');
let Plugins = require('./plugins.js');
let utils = require('../utils/utils.js');
var fs = require('./fs.js');
var Plugins = require('./plugins.js');
var utils = require('../utils/utils.js');
// TODO: add wrapper for fs so it can also work in the browser
// can work with both read and save
class Config {
constructor(options) {
var Config = function(options) {
this.env = options.env;
this.blockchainConfig = {};
this.contractsConfig = {};
@ -19,17 +18,16 @@ class Config {
this.plugins = options.plugins;
this.logger = options.logger;
this.events = options.events;
}
}
};
Config.prototype.loadConfigFiles = function(options) {
let interceptLogs = options.interceptLogs;
var interceptLogs = options.interceptLogs;
if (options.interceptLogs === undefined) {
interceptLogs = true;
}
//Check if the config file exists
let embarkConfigExists = fs.existsSync(options.embarkConfig);
var embarkConfigExists = fs.existsSync(options.embarkConfig);
if(!embarkConfigExists){
this.logger.error('Cannot find file ' + options.embarkConfig + '. Please ensure you are running this command inside the Dapp folder');
process.exit(1);
@ -38,22 +36,23 @@ Config.prototype.loadConfigFiles = function (options) {
this.embarkConfig = fs.readJSONSync(options.embarkConfig);
this.embarkConfig.plugins = this.embarkConfig.plugins || {};
this.plugins = new Plugins({
plugins: this.embarkConfig.plugins,
logger: this.logger,
interceptLogs: interceptLogs,
events: this.events,
config: this
});
this.plugins = new Plugins({plugins: this.embarkConfig.plugins, logger: this.logger, interceptLogs: interceptLogs, events: this.events, config: this});
this.plugins.loadPlugins();
this.load();
this.loadEmbarkConfigFile();
this.loadBlockchainConfigFile();
this.loadStorageConfigFile();
this.loadCommunicationConfigFile();
this.loadPipelineConfigFile();
this.loadContractsConfigFile();
this.loadWebServerConfigFile();
this.loadChainTrackerFile();
this.loadPluginContractFiles();
};
Config.prototype.load = Config.prototype.reloadConfig = function () {
Config.prototype.reloadConfig = function() {
this.loadEmbarkConfigFile();
this.loadBlockchainConfigFile();
this.loadStorageConfigFile();
@ -64,7 +63,7 @@ Config.prototype.load = Config.prototype.reloadConfig = function () {
};
Config.prototype.loadBlockchainConfigFile = function() {
let defaultBlockchainConfig = fs.readJSONSync(this.configDir + "blockchain.json");
var defaultBlockchainConfig = fs.readJSONSync(this.configDir + "blockchain.json");
this.blockchainConfig = defaultBlockchainConfig[this.env] || {};
if (this.blockchainConfig.enabled === undefined) {
@ -74,11 +73,9 @@ Config.prototype.loadBlockchainConfigFile = function () {
Config.prototype.loadContractsConfigFile = function() {
let configObject = {};
let configPlugins = [];
this.events.emit('get', 'contractsConfig', (kinds) => {
configPlugins = kinds;
});
var configObject = {};
var configPlugins = this.plugins.getPluginsFor('contractsConfig');
if (configPlugins.length > 0) {
configPlugins.forEach(function(plugin) {
plugin.contractsConfigs.forEach(function(pluginConfig) {
@ -87,17 +84,18 @@ Config.prototype.loadContractsConfigFile = function () {
});
}
let contractsConfig = fs.readJSONSync(this.configDir + "contracts.json");
var contractsConfig = fs.readJSONSync(this.configDir + "contracts.json");
configObject = utils.recursiveMerge(configObject, contractsConfig);
let defaultContractsConfig = configObject['default'];
let envContractsConfig = configObject[this.env];
var defaultContractsConfig = configObject['default'];
var envContractsConfig = configObject[this.env];
this.contractsConfig = utils.recursiveMerge(defaultContractsConfig, envContractsConfig);
var mergedConfig = utils.recursiveMerge(defaultContractsConfig, envContractsConfig);
this.contractsConfig = mergedConfig;
};
Config.prototype.loadStorageConfigFile = function() {
let configObject = {
var configObject = {
"default": {
"enabled": true,
"available_providers": ["ipfs"],
@ -106,10 +104,11 @@ Config.prototype.loadStorageConfigFile = function () {
"host": "localhost",
"port": 5001
},
"development": {}
"development": {
}
};
//let configPlugins = this.plugins.getPluginsFor('storageConfig');
//var configPlugins = this.plugins.getPluginsFor('storageConfig');
//if (configPlugins.length > 0) {
// configPlugins.forEach(function(plugin) {
// plugin.contractsConfigs.forEach(function(pluginConfig) {
@ -118,16 +117,16 @@ Config.prototype.loadStorageConfigFile = function () {
// });
//}
let storageConfig;
var storageConfig;
if (fs.existsSync(this.configDir + "storage.json")) {
storageConfig = fs.readJSONSync(this.configDir + "storage.json");
configObject = utils.recursiveMerge(configObject, storageConfig);
}
let defaultStorageConfig = configObject['default'];
let envStorageConfig = configObject[this.env];
var defaultStorageConfig = configObject['default'];
var envStorageConfig = configObject[this.env];
let mergedConfig = utils.recursiveMerge(defaultStorageConfig, envStorageConfig);
var mergedConfig = utils.recursiveMerge(defaultStorageConfig, envStorageConfig);
this.storageConfig = mergedConfig || {};
if (this.storageConfig.enabled === undefined) {
@ -139,7 +138,7 @@ Config.prototype.loadStorageConfigFile = function () {
};
Config.prototype.loadCommunicationConfigFile = function() {
let configObject = {
var configObject = {
"default": {
"enabled": true,
"provider": "whisper",
@ -147,7 +146,7 @@ Config.prototype.loadCommunicationConfigFile = function () {
}
};
//let configPlugins = this.plugins.getPluginsFor('communicationConfig');
//var configPlugins = this.plugins.getPluginsFor('communicationConfig');
//if (configPlugins.length > 0) {
// configPlugins.forEach(function(plugin) {
// plugin.contractsConfigs.forEach(function(pluginConfig) {
@ -156,17 +155,17 @@ Config.prototype.loadCommunicationConfigFile = function () {
// });
//}
let communicationConfig;
var communicationConfig;
if (fs.existsSync(this.configDir + "communication.json")) {
communicationConfig = fs.readJSONSync(this.configDir + "communication.json");
configObject = utils.recursiveMerge(configObject, communicationConfig);
}
let defaultCommunicationConfig = configObject['default'];
let envCommunicationConfig = configObject[this.env];
var defaultCommunicationConfig = configObject['default'];
var envCommunicationConfig = configObject[this.env];
let mergedConfig = utils.recursiveMerge(defaultCommunicationConfig, envCommunicationConfig);
var mergedConfig = utils.recursiveMerge(defaultCommunicationConfig, envCommunicationConfig);
this.communicationConfig = mergedConfig || {};
// TODO: probably not necessary if the default object is done right
@ -179,13 +178,13 @@ Config.prototype.loadCommunicationConfigFile = function () {
};
Config.prototype.loadWebServerConfigFile = function() {
let webServerConfigJSON;
var webServerConfigJSON;
if (fs.existsSync(this.configDir + "webserver.json")) {
webServerConfigJSON = fs.readJSONSync(this.configDir + "webserver.json");
} else {
webServerConfigJSON = {};
}
let defaultWebConfig = {
var defaultWebConfig = {
"enabled": true,
"host": "localhost",
"port": 8000
@ -194,7 +193,7 @@ Config.prototype.loadWebServerConfigFile = function () {
};
Config.prototype.loadEmbarkConfigFile = function() {
let contracts = this.embarkConfig.contracts;
var contracts = this.embarkConfig.contracts;
this.contractsFiles = this.loadFiles(contracts);
this.buildDir = this.embarkConfig.buildDir;
@ -202,15 +201,15 @@ Config.prototype.loadEmbarkConfigFile = function () {
};
Config.prototype.loadPipelineConfigFile = function() {
let assets = this.embarkConfig.app;
for (let targetFile in assets) {
var assets = this.embarkConfig.app;
for(var targetFile in assets) {
this.assetFiles[targetFile] = this.loadFiles(assets[targetFile]);
}
};
Config.prototype.loadChainTrackerFile = function() {
//let self = this;
let chainTracker;
//var self = this;
var chainTracker;
try {
chainTracker = fs.readJSONSync(this.chainsFile);
}
@ -223,9 +222,9 @@ Config.prototype.loadChainTrackerFile = function () {
};
Config.prototype.loadFiles = function(files) {
let self = this;
let originalFiles = utils.filesMatchingPattern(files);
let readFiles = [];
var self = this;
var originalFiles = utils.filesMatchingPattern(files);
var readFiles = [];
// get embark.js object first
originalFiles.filter(function(file) {
@ -234,54 +233,34 @@ Config.prototype.loadFiles = function (files) {
if (file === 'embark.js') {
if (self.blockchainConfig.enabled || self.communicationConfig.provider === 'whisper' || self.communicationConfig.available_providers.indexOf('whisper') >= 0) {
readFiles.push({
filename: 'web3.js',
content: fs.readFileSync(fs.embarkPath("js/web3.js")).toString(),
path: fs.embarkPath("js/web3.js")
});
readFiles.push({filename: 'web3.js', content: fs.readFileSync(fs.embarkPath("js/web3.js")).toString(), path: fs.embarkPath("js/web3.js")});
}
if (self.storageConfig.enabled && (self.storageConfig.provider === 'ipfs' || self.storageConfig.available_providers.indexOf('ipfs') >= 0)) {
readFiles.push({
filename: 'ipfs.js',
content: fs.readFileSync(fs.embarkPath("js/ipfs.js")).toString(),
path: fs.embarkPath("js/ipfs.js")
});
readFiles.push({filename: 'ipfs.js', content: fs.readFileSync(fs.embarkPath("js/ipfs.js")).toString(), path: fs.embarkPath("js/ipfs.js")});
}
if (self.communicationConfig.enabled && (self.communicationConfig.provider === 'orbit' || self.communicationConfig.available_providers.indexOf('orbit') >= 0)) {
// TODO: remove duplicated files if functionality is the same for storage and orbit
readFiles.push({
filename: 'ipfs-api.js',
content: fs.readFileSync(fs.embarkPath("js/ipfs-api.min.js")).toString(),
path: fs.embarkPath("js/ipfs-api.min.js")
});
readFiles.push({
filename: 'orbit.js',
content: fs.readFileSync(fs.embarkPath("js/orbit.min.js")).toString(),
path: fs.embarkPath("js/orbit.min.js")
});
readFiles.push({filename: 'ipfs-api.js', content: fs.readFileSync(fs.embarkPath("js/ipfs-api.min.js")).toString(), path: fs.embarkPath("js/ipfs-api.min.js")});
readFiles.push({filename: 'orbit.js', content: fs.readFileSync(fs.embarkPath("js/orbit.min.js")).toString(), path: fs.embarkPath("js/orbit.min.js")});
}
readFiles.push({
filename: 'embark.js',
content: fs.readFileSync(fs.embarkPath("js/build/embark.bundle.js")).toString(),
path: fs.embarkPath("js/build/embark.bundle.js")
});
readFiles.push({filename: 'embark.js', content: fs.readFileSync(fs.embarkPath("js/build/embark.bundle.js")).toString(), path: fs.embarkPath("js/build/embark.bundle.js")});
}
});
// get plugins
let filesFromPlugins = [];
var filesFromPlugins = [];
let filePlugins = self.plugins.getPluginsFor('pipelineFiles');
var filePlugins = self.plugins.getPluginsFor('pipelineFiles');
if (filePlugins.length > 0) {
filePlugins.forEach(function(plugin) {
try {
let fileObjects = plugin.runFilePipeline();
for (let i = 0; i < fileObjects.length; i++) {
let fileObject = fileObjects[i];
var fileObjects = plugin.runFilePipeline();
for (var i=0; i < fileObjects.length; i++) {
var fileObject = fileObjects[i];
filesFromPlugins.push(fileObject);
}
}
@ -314,18 +293,14 @@ Config.prototype.loadFiles = function (files) {
};
Config.prototype.loadPluginContractFiles = function() {
let self = this;
var self = this;
let contractsPlugins = this.plugins.getPluginsFor('contractFiles');
var contractsPlugins = this.plugins.getPluginsFor('contractFiles');
if (contractsPlugins.length > 0) {
contractsPlugins.forEach(function(plugin) {
plugin.contractsFiles.forEach(function(file) {
let filename = file.replace('./', '');
self.contractsFiles.push({
filename: filename,
content: plugin.loadPluginFile(file),
path: plugin.pathToFile(file)
});
var filename = file.replace('./','');
self.contractsFiles.push({filename: filename, content: plugin.loadPluginFile(file), path: plugin.pathToFile(file)});
});
});
}