2017-10-14 06:06:09 -04:00
|
|
|
const program = require('commander');
|
2017-03-30 22:16:46 +09:00
|
|
|
const Embark = require('../lib/index');
|
2018-07-20 21:55:20 +03:00
|
|
|
const i18n = require('./core/i18n/i18n.js');
|
2017-03-30 22:16:46 +09:00
|
|
|
let embark = new Embark;
|
2016-08-17 20:29:41 -04:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
class Cmd {
|
|
|
|
constructor() {
|
2017-03-30 22:16:46 +09:00
|
|
|
program.version(embark.version);
|
2017-02-17 14:34:07 -05:00
|
|
|
}
|
2016-08-17 20:29:41 -04:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
process(args) {
|
|
|
|
this.newApp();
|
|
|
|
this.demo();
|
|
|
|
this.build();
|
|
|
|
this.run();
|
2018-07-23 09:34:21 +01:00
|
|
|
this.console();
|
2017-03-30 20:12:39 +09:00
|
|
|
this.blockchain();
|
|
|
|
this.simulator();
|
|
|
|
this.test();
|
2018-01-11 09:22:58 -05:00
|
|
|
this.reset();
|
2018-03-22 10:43:29 -04:00
|
|
|
this.graph();
|
2018-05-09 17:02:17 -04:00
|
|
|
this.scaffold();
|
2017-03-30 20:12:39 +09:00
|
|
|
this.upload();
|
2017-12-19 10:20:05 -05:00
|
|
|
this.versionCmd();
|
2017-03-30 20:12:39 +09:00
|
|
|
this.otherCommands();
|
|
|
|
|
|
|
|
//If no arguments are passed display help by default
|
|
|
|
if (!process.argv.slice(2).length) {
|
|
|
|
program.help();
|
2016-08-21 10:42:42 -04:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
|
|
|
|
program.parse(args);
|
|
|
|
}
|
|
|
|
|
2017-10-14 06:06:09 -04:00
|
|
|
newApp() {
|
2017-03-30 20:12:39 +09:00
|
|
|
|
|
|
|
let validateName = function (value) {
|
|
|
|
try {
|
2017-10-14 06:06:09 -04:00
|
|
|
if (value.match(/^[a-zA-Z\s-]+$/)) return value;
|
2017-03-30 20:12:39 +09:00
|
|
|
} catch (e) {
|
2018-05-08 17:49:46 -04:00
|
|
|
throw new Error(__('Name must be only letters, spaces, or dashes'));
|
2017-03-22 14:13:58 +09:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
program
|
|
|
|
.command('new [name]')
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('New Application'))
|
|
|
|
.option('--simple', __('create a barebones project meant only for contract development'))
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-07-06 11:38:09 +03:00
|
|
|
.option('--template [url]', __('download template'))
|
2018-03-29 19:42:47 -04:00
|
|
|
.action(function (name, options) {
|
2018-05-09 18:46:38 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2017-03-30 20:12:39 +09:00
|
|
|
if (name === undefined) {
|
2018-06-01 11:57:01 -04:00
|
|
|
const promptly = require('promptly');
|
2018-05-08 17:49:46 -04:00
|
|
|
return promptly.prompt(__("Name your app (default is %s):", 'embarkDapp'), {
|
2017-06-27 15:45:30 -04:00
|
|
|
default: "embarkDApp",
|
2017-03-30 20:12:39 +09:00
|
|
|
validator: validateName
|
|
|
|
}, function (err, inputvalue) {
|
|
|
|
if (err) {
|
2018-05-08 17:49:46 -04:00
|
|
|
console.error(__('Invalid name') + ':', err.message);
|
2017-03-30 20:12:39 +09:00
|
|
|
// Manually call retry
|
|
|
|
// The passed error has a retry method to easily prompt again.
|
|
|
|
err.retry();
|
|
|
|
} else {
|
|
|
|
//slightly different assignment of name since it comes from child prompt
|
2018-03-29 19:42:47 -04:00
|
|
|
if (options.simple) {
|
|
|
|
embark.generateTemplate('simple', './', inputvalue);
|
|
|
|
} else {
|
2018-07-06 11:38:09 +03:00
|
|
|
embark.generateTemplate('boilerplate', './', inputvalue, options.template);
|
2018-03-29 19:42:47 -04:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
}
|
|
|
|
});
|
|
|
|
} else {
|
2018-03-29 19:42:47 -04:00
|
|
|
if (options.simple) {
|
|
|
|
embark.generateTemplate('simple', './', name);
|
|
|
|
} else {
|
2018-07-06 11:38:09 +03:00
|
|
|
embark.generateTemplate('boilerplate', './', name, options.template);
|
2018-03-29 19:42:47 -04:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
demo() {
|
|
|
|
program
|
|
|
|
.command('demo')
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('create a working dapp with a SimpleStorage contract'))
|
2018-05-10 15:36:24 -04:00
|
|
|
.action(function (options) {
|
2018-05-09 18:46:38 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2017-03-30 22:16:46 +09:00
|
|
|
embark.generateTemplate('demo', './', 'embark_demo');
|
2017-03-30 20:12:39 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
build() {
|
|
|
|
program
|
|
|
|
.command('build [environment]')
|
2018-05-17 15:37:57 -05:00
|
|
|
.option('--contracts', 'only compile contracts into Embark wrappers')
|
2018-05-08 17:49:46 -04:00
|
|
|
.option('--logfile [logfile]', __('filename to output logs (default: none)'))
|
2018-05-22 15:46:02 -04:00
|
|
|
.option('-c, --client [client]', __('Use a specific ethereum client or simulator (supported: %s)', 'geth, testrpc'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.option('--loglevel [loglevel]', __('level of logging to display') + ' ["error", "warn", "info", "debug", "trace"]', /^(error|warn|info|debug|trace)$/i, 'debug')
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('deploy and build dapp at ') + 'dist/ (default: development)')
|
2017-10-14 06:06:09 -04:00
|
|
|
.action(function (env, _options) {
|
2018-05-10 15:36:24 -04:00
|
|
|
i18n.setOrDetectLocale(_options.locale);
|
2018-04-19 14:25:43 +10:00
|
|
|
_options.env = env || 'development';
|
|
|
|
_options.logFile = _options.logfile; // fix casing
|
|
|
|
_options.logLevel = _options.loglevel; // fix casing
|
2018-05-17 15:37:57 -05:00
|
|
|
_options.onlyCompile = _options.contracts;
|
2018-05-22 15:46:02 -04:00
|
|
|
_options.client = _options.client || 'geth';
|
2018-04-19 14:25:43 +10:00
|
|
|
embark.build(_options);
|
2017-03-30 20:12:39 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
run() {
|
|
|
|
program
|
|
|
|
.command('run [environment]')
|
2018-05-08 17:49:46 -04:00
|
|
|
.option('-p, --port [port]', __('port to run the dev webserver (default: %s)', '8000'))
|
2018-05-18 15:48:28 -04:00
|
|
|
.option('-c, --client [client]', __('Use a specific ethereum client or simulator (supported: %s)', 'geth, testrpc'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.option('-b, --host [host]', __('host to run the dev webserver (default: %s)', 'localhost'))
|
|
|
|
.option('--noserver', __('disable the development webserver'))
|
|
|
|
.option('--nodashboard', __('simple mode, disables the dashboard'))
|
|
|
|
.option('--no-color', __('no colors in case it\'s needed for compatbility purposes'))
|
|
|
|
.option('--logfile [logfile]', __('filename to output logs (default: %s)', 'none'))
|
|
|
|
.option('--loglevel [loglevel]', __('level of logging to display') + ' ["error", "warn", "info", "debug", "trace"]', /^(error|warn|info|debug|trace)$/i, 'debug')
|
2018-05-09 18:43:09 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('run dapp (default: %s)', 'development'))
|
2017-03-30 20:12:39 +09:00
|
|
|
.action(function (env, options) {
|
2018-05-09 18:43:09 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2017-03-30 22:16:46 +09:00
|
|
|
embark.run({
|
2017-03-30 20:12:39 +09:00
|
|
|
env: env || 'development',
|
|
|
|
serverPort: options.port,
|
2018-07-23 09:34:21 +01:00
|
|
|
serverHost: options.host,
|
|
|
|
client: options.client || 'geth',
|
|
|
|
locale: options.locale,
|
|
|
|
runWebserver: !options.noserver,
|
|
|
|
useDashboard: !options.nodashboard,
|
|
|
|
logFile: options.logfile,
|
|
|
|
logLevel: options.loglevel
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
console() {
|
|
|
|
program
|
|
|
|
.command('console [environment]')
|
|
|
|
.option('-c, --client [client]', __('Use a specific ethereum client or simulator (supported: %s)', 'geth, testrpc'))
|
|
|
|
.option('--logfile [logfile]', __('filename to output logs (default: %s)', 'none'))
|
|
|
|
.option('--loglevel [loglevel]', __('level of logging to display') + ' ["error", "warn", "info", "debug", "trace"]', /^(error|warn|info|debug|trace)$/i, 'debug')
|
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-07-23 13:36:15 +01:00
|
|
|
.description(__('Start the Embark console'))
|
2018-07-23 09:34:21 +01:00
|
|
|
.action(function (env, options) {
|
|
|
|
i18n.setOrDetectLocale(options.locale);
|
|
|
|
embark.console({
|
|
|
|
env: env || 'development',
|
2018-05-18 15:48:28 -04:00
|
|
|
client: options.client || 'geth',
|
|
|
|
locale: options.locale,
|
2018-04-19 14:25:43 +10:00
|
|
|
logFile: options.logfile,
|
|
|
|
logLevel: options.loglevel
|
2017-03-30 20:12:39 +09:00
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
blockchain() {
|
|
|
|
program
|
|
|
|
.command('blockchain [environment]')
|
2018-05-08 17:49:46 -04:00
|
|
|
.option('-c, --client [client]', __('Use a specific ethereum client or simulator (supported: %s)', 'geth, testrpc'))
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('run blockchain server (default: %s)', 'development'))
|
2017-03-30 20:12:39 +09:00
|
|
|
.action(function (env, options) {
|
2018-05-09 18:46:38 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2017-03-30 22:16:46 +09:00
|
|
|
embark.initConfig(env || 'development', {
|
2017-03-30 20:12:39 +09:00
|
|
|
embarkConfig: 'embark.json',
|
|
|
|
interceptLogs: false
|
|
|
|
});
|
2017-03-30 22:16:46 +09:00
|
|
|
embark.blockchain(env || 'development', options.client || 'geth');
|
2017-03-30 20:12:39 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
simulator() {
|
|
|
|
program
|
|
|
|
.command('simulator [environment]')
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('run a fast ethereum rpc simulator'))
|
|
|
|
.option('--testrpc', __('use testrpc as the rpc simulator [%s]', 'default'))
|
|
|
|
.option('-p, --port [port]', __('port to run the rpc simulator (default: %s)', '8545'))
|
|
|
|
.option('-h, --host [host]', __('host to run the rpc simulator (default: %s)', 'localhost'))
|
|
|
|
.option('-a, --accounts [numAccounts]', __('number of accounts (default: %s)', '10'))
|
|
|
|
.option('-e, --defaultBalanceEther [balance]', __('Amount of ether to assign each test account (default: %s)', '100'))
|
|
|
|
.option('-l, --gasLimit [gasLimit]', __('custom gas limit (default: %s)', '8000000'))
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2017-12-27 17:48:33 -05:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
.action(function (env, options) {
|
2018-05-09 18:46:38 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2017-03-30 22:16:46 +09:00
|
|
|
embark.initConfig(env || 'development', {
|
2017-03-30 20:12:39 +09:00
|
|
|
embarkConfig: 'embark.json',
|
|
|
|
interceptLogs: false
|
|
|
|
});
|
2017-12-27 17:48:33 -05:00
|
|
|
embark.simulator({
|
|
|
|
port: options.port,
|
|
|
|
host: options.host,
|
|
|
|
numAccounts: options.numAccounts,
|
|
|
|
defaultBalance: options.balance,
|
|
|
|
gasLimit: options.gasLimit
|
|
|
|
});
|
2017-03-30 20:12:39 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
test() {
|
|
|
|
program
|
2017-07-02 11:32:16 -04:00
|
|
|
.command('test [file]')
|
2018-07-06 15:16:04 -04:00
|
|
|
.option('-d , --gasDetails', __('When set, will print the gas cost for each contract deploy'))
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-06-13 09:44:19 -04:00
|
|
|
.option('--loglevel [loglevel]', __('level of logging to display') + ' ["error", "warn", "info", "debug", "trace"]', /^(error|warn|info|debug|trace)$/i, 'warn')
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('run tests'))
|
2018-05-10 15:26:09 -04:00
|
|
|
.action(function (file, options) {
|
2018-05-09 18:46:38 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2018-06-28 15:48:57 -04:00
|
|
|
embark.runTests({file, loglevel: options.loglevel, gasDetails: options.gasDetails});
|
2017-03-30 20:12:39 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
upload() {
|
|
|
|
program
|
2018-05-17 17:38:17 +10:00
|
|
|
.command('upload [environment]')
|
2018-05-08 17:49:46 -04:00
|
|
|
.option('--logfile [logfile]', __('filename to output logs (default: %s)', 'none'))
|
|
|
|
.option('--loglevel [loglevel]', __('level of logging to display') + ' ["error", "warn", "info", "debug", "trace"]', /^(error|warn|info|debug|trace)$/i, 'debug')
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-05-22 15:46:58 -04:00
|
|
|
.option('-c, --client [client]', __('Use a specific ethereum client or simulator (supported: %s)', 'geth, testrpc'))
|
2018-05-30 16:34:36 +10:00
|
|
|
.description(__('Upload your dapp to a decentralized storage') + '.')
|
2018-05-17 17:38:17 +10:00
|
|
|
.action(function (env, _options) {
|
2018-05-10 15:36:24 -04:00
|
|
|
i18n.setOrDetectLocale(_options.locale);
|
2018-06-19 14:07:14 -04:00
|
|
|
if (env === "ipfs" || env === "swarm") {
|
|
|
|
console.warn(("did you mean " + "embark upload".bold + " ?").underline);
|
|
|
|
console.warn("In embark 3.1 forwards, the correct command is embark upload <environment> and the provider is configured in config/storage.js");
|
|
|
|
}
|
2018-04-24 10:27:11 +10:00
|
|
|
_options.env = env || 'development';
|
2018-04-19 14:25:43 +10:00
|
|
|
_options.logFile = _options.logfile; // fix casing
|
|
|
|
_options.logLevel = _options.loglevel; // fix casing
|
2018-05-22 15:46:58 -04:00
|
|
|
_options.client = _options.client || 'geth';
|
2018-05-17 17:38:17 +10:00
|
|
|
embark.upload(_options);
|
2017-03-30 20:12:39 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-03-22 10:43:29 -04:00
|
|
|
graph() {
|
|
|
|
program
|
|
|
|
.command('graph [environment]')
|
2018-05-08 17:49:46 -04:00
|
|
|
.option('--skip-undeployed', __('Graph will not include undeployed contracts'))
|
|
|
|
.option('--skip-functions', __('Graph will not include functions'))
|
|
|
|
.option('--skip-events', __('Graph will not include events'))
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('generates documentation based on the smart contracts configured'))
|
2018-03-22 10:43:29 -04:00
|
|
|
.action(function (env, options) {
|
2018-05-09 18:46:38 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2018-03-22 15:09:01 -04:00
|
|
|
embark.graph({
|
|
|
|
env: env || 'development',
|
2018-05-04 16:17:12 -04:00
|
|
|
logFile: options.logfile,
|
|
|
|
skipUndeployed: options.skipUndeployed,
|
|
|
|
skipFunctions: options.skipFunctions,
|
|
|
|
skipEvents: options.skipEvents
|
2018-03-22 10:43:29 -04:00
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-05-09 17:02:17 -04:00
|
|
|
scaffold() {
|
|
|
|
program
|
|
|
|
.command('scaffold [contract] [environment]')
|
2018-05-11 16:07:28 -04:00
|
|
|
.option('--framework <framework>', 'UI framework to use. (default: react)')
|
2018-05-09 17:02:17 -04:00
|
|
|
.action(function(contract, env, options){
|
2018-05-11 16:07:28 -04:00
|
|
|
|
2018-05-09 17:02:17 -04:00
|
|
|
let environment = env || 'development';
|
|
|
|
|
|
|
|
if(contract === undefined){
|
|
|
|
console.log("contract name is required");
|
|
|
|
process.exit(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
embark.initConfig(environment, {
|
|
|
|
embarkConfig: 'embark.json', interceptLogs: false
|
|
|
|
});
|
|
|
|
|
|
|
|
options.contract = contract;
|
2018-05-11 16:07:28 -04:00
|
|
|
options.framework = options.framework || 'react';
|
2018-05-09 17:02:17 -04:00
|
|
|
options.env = environment;
|
|
|
|
embark.scaffold(options);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-01-11 09:22:58 -05:00
|
|
|
reset() {
|
|
|
|
program
|
|
|
|
.command('reset')
|
2018-05-09 18:46:38 -04:00
|
|
|
.option('--locale [locale]', __('language to use (default: en)'))
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('resets embarks state on this dapp including clearing cache'))
|
2018-05-10 15:36:24 -04:00
|
|
|
.action(function (options) {
|
2018-05-09 18:46:38 -04:00
|
|
|
i18n.setOrDetectLocale(options.locale);
|
2018-01-11 09:22:58 -05:00
|
|
|
embark.initConfig('development', {
|
|
|
|
embarkConfig: 'embark.json', interceptLogs: false
|
|
|
|
});
|
|
|
|
embark.reset();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-12-19 10:20:05 -05:00
|
|
|
versionCmd() {
|
|
|
|
program
|
|
|
|
.command('version')
|
2018-05-08 17:49:46 -04:00
|
|
|
.description(__('output the version number'))
|
2017-12-19 10:20:05 -05:00
|
|
|
.action(function () {
|
|
|
|
console.log(embark.version);
|
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
otherCommands() {
|
|
|
|
program
|
2017-12-19 13:29:48 -05:00
|
|
|
.action(function (cmd) {
|
2018-05-08 17:49:46 -04:00
|
|
|
console.log((__('unknown command') + ' "%s"').red, cmd);
|
2018-06-01 11:57:01 -04:00
|
|
|
let utils = require('./utils/utils.js');
|
2017-12-19 15:48:56 -05:00
|
|
|
let dictionary = ['new', 'demo', 'build', 'run', 'blockchain', 'simulator', 'test', 'upload', 'version'];
|
2017-12-19 14:07:48 -05:00
|
|
|
let suggestion = utils.proposeAlternative(cmd, dictionary);
|
2017-12-19 13:29:48 -05:00
|
|
|
if (suggestion) {
|
2018-05-08 17:49:46 -04:00
|
|
|
console.log((__('did you mean') + ' "%s"?').green, suggestion);
|
2017-12-19 13:29:48 -05:00
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
console.log("type embark --help to see the available commands");
|
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
}
|
2017-03-22 14:13:58 +09:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
}
|
2016-08-17 20:29:41 -04:00
|
|
|
|
|
|
|
module.exports = Cmd;
|