let async = require('async'); // require("./utils/debug_util.js")(__filename, async); require('colors'); // Override process.chdir so that we have a partial-implementation PWD for Windows const realChdir = process.chdir; process.chdir = (...args) => { if (!process.env.PWD) { process.env.PWD = process.cwd(); } realChdir(...args); }; let Engine = require('./core/engine.js'); let version = require('../package.json').version; class Embark { constructor (options) { this.version = version; this.options = options || {}; } initConfig(env, options) { let Events = require('./core/events.js'); let Logger = require('./core/logger.js'); let Config = require('./core/config.js'); this.events = new Events(); this.logger = new Logger({logLevel: 'debug', events: this.events}); this.config = new Config({env: env, logger: this.logger, events: this.events}); this.config.loadConfigFiles(options); this.plugins = this.config.plugins; } blockchain(env, client) { return require('./cmds/blockchain/blockchain.js')(this.config.blockchainConfig, client, env).run(); } simulator(options) { let Simulator = require('./cmds/simulator.js'); let simulator = new Simulator({blockchainConfig: this.config.blockchainConfig}); simulator.run(options); } generateTemplate(templateName, destinationFolder, name) { let TemplateGenerator = require('./cmds/template_generator.js'); let templateGenerator = new TemplateGenerator(templateName); templateGenerator.generate(destinationFolder, name); } run(options) { let self = this; let Dashboard = require('./dashboard/dashboard.js'); let windowSize = require('window-size'); let engine = new Engine({ env: options.env, version: this.version, embarkConfig: options.embarkConfig || 'embark.json', logfile: options.logfile }); engine.init(); if (!options.useDashboard) { console.log('========================'.bold.green); console.log(('Welcome to Embark ' + this.version).yellow.bold); console.log('========================'.bold.green); } async.parallel([ function startDashboard(callback) { if (!options.useDashboard) { return callback(); } let dashboard = new Dashboard({ events: engine.events, logger: engine.logger, plugins: engine.plugins, version: self.version, env: engine.env, contractsConfig: engine.config.contractsConfig }); dashboard.start(function () { engine.events.on('code-generator-ready', function () { engine.events.request('code-vanila-deployment', function (abi) { dashboard.console.runCode(abi); }); }); engine.logger.info('dashboard start'); callback(); }); }, function (callback) { let pluginList = engine.plugins.listPlugins(); if (pluginList.length > 0) { engine.logger.info("loaded plugins: " + pluginList.join(", ")); } engine.startMonitor(); engine.startService("libraryManager"); engine.startService("web3"); engine.startService("pipeline"); engine.startService("codeGenerator"); engine.startService("deployment"); engine.startService("ipfs"); engine.events.on('check:backOnline:Ethereum', function () { engine.logger.info('Ethereum node detected..'); engine.config.reloadConfig(); engine.deployManager.deployContracts(function () { engine.logger.info('Deployment Done'); }); }); engine.events.on('outputDone', function () { engine.logger.info("Looking for documentation? You can find it at ".cyan + "http://embark.readthedocs.io/".green.underline + ".".cyan); engine.logger.info("Ready".underline); }); engine.deployManager.deployContracts(function (err) { engine.startService("fileWatcher"); if (options.runWebserver) { engine.startService("webServer", { host: options.serverHost, port: options.serverPort }); } callback(err); }); } ], function (err, _result) { if (err) { engine.logger.error(err.message); engine.logger.info(err.stack); } else { engine.events.emit('firstDeploymentDone'); engine.events.emit("status", "Ready".green); let size = windowSize.get(); if (size.height < 40 || size.width < 118) { engine.logger.warn("tip: you can resize the terminal or disable the dashboard with " + "embark run --nodashboard".bold.underline); } } }); } build(options, engine, continueProcessing) { if(!engine){ engine = new Engine({ env: options.env, version: this.version, embarkConfig: 'embark.json', interceptLogs: false }); engine.init(); } async.waterfall([ function startServices(callback) { let pluginList = engine.plugins.listPlugins(); if (pluginList.length > 0) { engine.logger.info("loaded plugins: " + pluginList.join(", ")); } engine.startService("libraryManager"); engine.startService("web3"); engine.startService("pipeline"); engine.startService("codeGenerator"); engine.startService("deployment"); engine.startService("ipfs"); callback(); }, function deploy(callback) { engine.deployManager.deployContracts(function (err) { callback(err); }); } ], function (err, _result) { if (err) { engine.logger.error(err.message); engine.logger.debug(err.stack); } else { engine.logger.info("finished building".underline); } // needed due to child processes if(err || !continueProcessing){ process.exit(); } }); } initTests(options) { let Test = require('./tests/test.js'); return new Test(options); } graph(options) { options.onlyCompile = true; let engine = new Engine({ env: options.env, version: this.version, embarkConfig: options.embarkConfig || 'embark.json', logfile: options.logfile }); engine.init(); async.parallel([ function (callback) { let pluginList = engine.plugins.listPlugins(); if (pluginList.length > 0) { engine.logger.info("loaded plugins: " + pluginList.join(", ")); } engine.startMonitor(); engine.startService("libraryManager"); engine.startService("pipeline"); engine.startService("codeGenerator"); engine.startService("deployment", {onlyCompile: true}); engine.deployManager.deployContracts(function (err) { callback(err); }); } ], function (err, _result) { if (err) { engine.logger.error(err.message); engine.logger.info(err.stack); } else { const GraphGenerator = require('./cmds/graph.js'); let graphGen = new GraphGenerator(engine); graphGen.generate(); engine.logger.info("Done".underline); process.exit(); } }); } reset() { let resetCmd = require('./cmds/reset.js'); resetCmd(); } scaffold(options) { // initialise embark engine let engine = new Engine({ env: options.env, version: this.version, embarkConfig: options.embarkConfig || 'embark.json', logfile: options.logfile }); engine.init(); // load plugins this.plugins.loadInternalPlugin('scaffolding', options); let scaffoldPlugin = this.plugins.plugins.filter(x => x.name == "scaffolding")[0].pluginModule; let self = this; async.waterfall([ function generateUI(callback){ engine.events.on('contractsDeployed', function () { let scaffold = new scaffoldPlugin(engine, options); let result = scaffold.generate(options.contract); engine.logger.info(result); callback(); }); self.build(options, engine, false); } ], function (err, _result) { if (err) { engine.logger.error(err.message); engine.logger.debug(err.stack); } else { engine.logger.info("finished generating ui"); } process.exit(); }); } upload(platform, options) { options.buildDir = 'dist/'; options.storageConfig = this.config.storageConfig; // initialise embark engine let engine = new Engine({ env: options.env, version: this.version, embarkConfig: options.embarkConfig || 'embark.json', logfile: options.logfile }); engine.init(); // load plugins this.plugins.loadInternalPlugin('ipfs', options); this.plugins.loadInternalPlugin('swarm', options); let plugins = this.plugins; let cmdPlugin; let self = this; async.waterfall([ function setupStoragePlugin(callback){ // check use has input existing storage plugin let cmdPlugins = plugins.getPluginsFor('uploadCmds'); if (cmdPlugins.length > 0) { cmdPlugin = cmdPlugins.find((pluginCmd) => { return pluginCmd.name == platform; }); } if (!cmdPlugin) { engine.logger.info('try "embark upload ipfs" or "embark upload swarm"'.green); callback({message: 'unknown platform: ' + platform}); } else { callback(); } }, function buildAndDeployContracts(callback){ // 2. upload to storage (outputDone event triggered after webpack finished) engine.events.on('outputDone', function () { engine.logger.info('deploying to ' + platform + '...'); cmdPlugin.uploadCmds[0].cb() .then((success) => { callback(null, success); }) .catch(callback); }); // 1. build the contracts and dapp webpack self.build(options, engine, true); } ], function (err, _result) { if (err) { engine.logger.error(err.message); engine.logger.debug(err.stack); } else { engine.logger.info("finished building dapp and deploying to " + platform.underline); } // needed due to child processes process.exit(); }); } runTests(file) { let RunTests = require('./tests/run_tests.js'); RunTests.run(file); } } // temporary until next refactor Embark.initTests = function(options) { let Test = require('./tests/test.js'); return new Test(options); }; module.exports = Embark;