refactor: change registerConsoleCommands to the new API

This commit is contained in:
Jonathan Rainville 2018-12-14 11:43:05 -05:00
parent bbcfe9b1de
commit a147e2706b
10 changed files with 221 additions and 230 deletions

View File

@ -70,14 +70,13 @@ class Authenticator {
} }
); );
this.embark.registerConsoleCommand((cmd, _options) => { this.embark.registerConsoleCommand({
return { matches: ["token"],
match: () => cmd === "token", description: __("Copies and prints the token for the cockpit"),
process: (callback) => { process: (cmd, callback) => {
utils.copyToClipboard(this.authToken); utils.copyToClipboard(this.authToken);
callback(null, __('Token copied to clipboard: %s', this.authToken)); callback(null, __('Token copied to clipboard: %s', this.authToken));
} }
};
}); });
} }

View File

@ -49,19 +49,17 @@ class BlockchainModule {
} }
registerConsoleCommands() { registerConsoleCommands() {
const self = this; this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { matches: ['log blockchain on'],
return { process: (cmd, callback) => {
match: () => cmd === 'log blockchain on', this.events.request('logs:ethereum:turnOn', callback);
process: (cb) => self.events.request('logs:ethereum:turnOn', cb) }
};
}); });
this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { matches: ['log blockchain off'],
return { process: (cmd, callback) => {
match: () => cmd === 'log blockchain off', this.events.request('logs:ethereum:turnOff', callback);
process: (cb) => self.events.request('logs:ethereum:turnOff', cb) }
};
}); });
} }

View File

@ -89,20 +89,11 @@ class Console {
__("possible commands are:"), __("possible commands are:"),
// TODO: only if the blockchain is actually active! // TODO: only if the blockchain is actually active!
// will need to pass te current embark state here // will need to pass te current embark state here
"ipfs - " + __("instantiated js-ipfs object configured to the current environment (available if ipfs is enabled)"), "ipfs".cyan + " - " + __("instantiated js-ipfs object configured to the current environment (available if ipfs is enabled)"),
"swarm - " + __("instantiated swarm-api object configured to the current environment (available if swarm is enabled)"), "swarm".cyan + " - " + __("instantiated swarm-api object configured to the current environment (available if swarm is enabled)"),
"web3 - " + __("instantiated web3.js object configured to the current environment"), "web3".cyan + " - " + __("instantiated web3.js object configured to the current environment"),
"EmbarkJS - " + __("EmbarkJS static functions for Storage, Messages, Names, etc."), "EmbarkJS".cyan + " - " + __("EmbarkJS static functions for Storage, Messages, Names, etc."),
"token - " + __("Copies and prints the token for the cockpit"), "log <process> on/off".cyan + " - " + __("Activate or deactivate the logs of a sub-process. Options: blockchain, ipfs, webserver"),
"debug <txHash> - " + __("Debug the last transaction or the transaction specified by a hash"),
" next/n - " + __("During a debug, step over forward"),
" previous/p - " + __("During a debug, step over back"),
" var local/v l/vl - " + __("During a debug, display local variables"),
" var global/v g/vg - " + __("During a debug, display global variables"),
" var all/v a/va - " + __("During a debug, display all variables"),
" var all/v a/va - " + __("During a debug, display all variables"),
"log <process> on/off - " + __("Activate or deactivate the logs of a sub-process. Options: blockchain, "),
"plugin install <package> - " + __("Installs a plugin in the Dapp. eg: plugin install embark-solc"),
]; ];
helpDescriptions.forEach((helpDescription) => { helpDescriptions.forEach((helpDescription) => {
let matches = [] as string[]; let matches = [] as string[];

View File

@ -217,127 +217,131 @@ class TransactionDebugger {
this.cmdDebugger = false; this.cmdDebugger = false;
this.currentCmdTxHash = ""; this.currentCmdTxHash = "";
this.embark.registerConsoleCommand((cmd: string, options: any) => { this.embark.registerConsoleCommand({
const cmdName = cmd.split(" ")[0]; description: __("Debug the last transaction or the transaction specified by a hash"),
const txHash = cmd.split(" ")[1]; matches: (cmd: string) => {
return { const [cmdName] = cmd.split(" ");
match: () => cmdName === "debug", return cmdName === "debug";
process: (cb: any) => { },
if (txHash) { process: (cmd: string, callback: (err?: string|object, output?: string) => void) => {
this.embark.events.request("contracts:contract:byTxHash", txHash, (err: any, contract: any) => { const [_cmdName, txHash] = cmd.split(" ");
if (err) { if (txHash) {
this.embark.logger.error(err); this.embark.events.request("contracts:contract:byTxHash", txHash, (err: any, contract: any) => {
return;
}
this.currentCmdTxHash = txHash;
this.embark.logger.info("debugging tx " + txHash);
this.cmdDebugger = this.debuggerManager.createDebuggerSession(txHash, contract.filename, () => {
this.displayStepInfo();
});
});
return;
}
this.currentCmdTxHash = this.lastTx;
const filename: string = this.txTracker[this.lastTx].contract.filename;
this.embark.logger.info("debugging tx " + this.lastTx);
this.cmdDebugger = this.debuggerManager.createDebuggerSession(this.lastTx, filename, () => {
this.displayStepInfo();
});
},
};
});
this.embark.registerConsoleCommand((cmd: string, options: any) => {
return {
match: () => (cmd === "next" || cmd === "n"),
process: (cb: any) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return cb();
}
if (!this.cmdDebugger.canGoNext()) {
return cb();
}
if (!this.cmdDebugger.currentStep()) {
this.embark.logger.info("end of execution reached");
this.cmdDebugger.unload();
return cb();
}
this.cmdDebugger.stepOverForward(true);
this.displayStepInfo();
cb();
},
};
});
this.embark.registerConsoleCommand((cmd: string, options: any) => {
return {
match: () => (cmd === "previous" || cmd === "p"),
process: (cb: any) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return cb();
}
if (!this.cmdDebugger.canGoPrevious()) {
return cb();
}
if (!this.cmdDebugger.currentStep()) {
this.embark.logger.info("end of execution reached");
return this.cmdDebugger.unload();
}
this.cmdDebugger.stepOverBack(true);
this.displayStepInfo();
cb();
},
};
});
this.embark.registerConsoleCommand((cmd: string, options: any) => {
return {
match: () => (cmd === "var local" || cmd === "v l" || cmd === "vl"),
process: (cb: any) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return cb();
}
this.cmdDebugger.displayLocals();
cb();
},
};
});
this.embark.registerConsoleCommand((cmd: string, options: any) => {
return {
match: () => (cmd === "var global" || cmd === "v g" || cmd === "vg"),
process: (cb: any) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return cb();
}
this.cmdDebugger.displayGlobals();
cb();
},
};
});
this.embark.registerConsoleCommand((cmd: string, options: any) => {
return {
match: () => (cmd === "var all" || cmd === "v a" || cmd === "va"),
process: (cb: any) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return cb();
}
this.getGlobals(this.currentCmdTxHash, (err: any, globals: any) => {
if (err) { if (err) {
this.embark.logger.error(err); this.embark.logger.error(err);
return cb(); return callback();
} }
this.embark.logger.info(globals); this.currentCmdTxHash = txHash;
cb(); this.embark.logger.info("debugging tx " + txHash);
this.cmdDebugger = this.debuggerManager.createDebuggerSession(txHash, contract.filename, () => {
this.displayStepInfo();
callback();
});
}); });
}, return;
}; }
this.currentCmdTxHash = this.lastTx;
const filename: string = this.txTracker[this.lastTx].contract.filename;
this.embark.logger.info("debugging tx " + this.lastTx);
this.cmdDebugger = this.debuggerManager.createDebuggerSession(this.lastTx, filename, () => {
this.displayStepInfo();
callback();
});
},
usage: "debug <txHash>",
});
this.embark.registerConsoleCommand({
description: __("During a debug, step over forward"),
matches: ["next", "n"],
process: (cmd: string, callback: (err?: string|object, output?: string) => void) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return callback();
}
if (!this.cmdDebugger.canGoNext()) {
return callback();
}
if (!this.cmdDebugger.currentStep()) {
this.embark.logger.info("end of execution reached");
this.cmdDebugger.unload();
return callback();
}
this.cmdDebugger.stepOverForward(true);
this.displayStepInfo();
callback();
},
usage: " next/n",
});
this.embark.registerConsoleCommand({
description: __("During a debug, step over back"),
matches: ["previous", "p"],
process: (cmd: string, callback: (err?: string|object, output?: string) => void) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return callback();
}
if (!this.cmdDebugger.canGoPrevious()) {
return callback();
}
if (!this.cmdDebugger.currentStep()) {
this.embark.logger.info("end of execution reached");
return this.cmdDebugger.unload();
}
this.cmdDebugger.stepOverBack(true);
this.displayStepInfo();
callback();
},
usage: " previous/p",
});
this.embark.registerConsoleCommand({
description: __("During a debug, display local variables"),
matches: ["var local", "v l", "vl"],
process: (cmd: string, callback: (err?: string|object, output?: string) => void) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return callback();
}
this.cmdDebugger.displayLocals();
callback();
},
usage: " var local/v l/vl",
});
this.embark.registerConsoleCommand({
description: __("During a debug, display global variables"),
matches: ["var global", "v g", "vg"],
process: (cmd: string, callback: (err?: string|object, output?: string) => void) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return callback();
}
this.cmdDebugger.displayGlobals();
callback();
},
usage: " var global/v g/vg",
});
this.embark.registerConsoleCommand({
description: __("During a debug, display all variables"),
matches: ["var all", "v a", "va"],
process: (cmd: string, callback: (err?: string|object, output?: string) => void) => {
if (!this.cmdDebugger) {
this.embark.logger.warn(NO_DEBUG_SESSION);
return callback();
}
this.getGlobals(this.currentCmdTxHash, (err: any, globals: any) => {
if (err) {
this.embark.logger.error(err);
return callback();
}
this.embark.logger.info(globals);
callback();
});
},
usage: " var all/v a/va",
}); });
} }

View File

@ -154,19 +154,17 @@ class IPFS {
} }
registerConsoleCommands() { registerConsoleCommands() {
const self = this; this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { matches: ['log ipfs on'],
return { process: (cmd, callback) => {
match: () => cmd === 'log ipfs on', this.events.request('logs:ipfs:turnOn', callback);
process: (cb) => self.events.request('logs:ipfs:turnOn', cb) }
};
}); });
this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { matches: ['log ipfs off'],
return { process: (cmd, callback) => {
match: () => cmd === 'log ipfs off', this.events.request('logs:ipfs:turnOff', callback);
process: (cb) => self.events.request('logs:ipfs:turnOff', cb) }
};
}); });
} }

View File

@ -11,14 +11,18 @@ class PluginCommand {
} }
registerCommand() { registerCommand() {
this.embark.registerConsoleCommand((cmd, _options) => { this.embark.registerConsoleCommand({
let cmdArray = cmd.split(' '); description: "Installs a plugin in the Dapp. eg: plugin install embark-solc",
cmdArray = cmdArray.filter(cmd => cmd.trim().length > 0); usage: "plugin install <package>",
let cmdName = cmdArray[0]; matches: (cmd) => {
return { const [cmdName] = cmd.split(' ');
match: () => cmdName === 'plugin', return cmdName === 'plugin';
process: this.installPlugin.bind(this, cmdArray) },
}; process: (cmd, callback) => {
let cmdArray = cmd.split(' ');
cmdArray = cmdArray.filter(cmd => cmd.trim().length > 0);
this.installPlugin(cmdArray, callback);
}
}); });
} }

View File

@ -69,31 +69,28 @@ class Profiler {
} }
registerConsoleCommand() { registerConsoleCommand() {
const self = this; this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { description: "Outputs the function profile of a contract",
let cmdName = cmd.split(' ')[0]; usage: "profile <contractName>",
let contractName = cmd.split(' ')[1]; matches: (cmd) => {
const [cmdName] = cmd.split(' ');
return { return cmdName === 'profile';
match: () => cmdName === 'profile', },
process: (callback) => { process: (cmd, callback) => {
this.profile(contractName, callback); const [_cmdName, contractName] = cmd.split(' ');
} this.profile(contractName, callback);
}; }
}); });
} }
registerApi() { registerApi() {
const self = this; this.embark.registerAPICall(
let plugin = this.plugins.createPlugin('profiler', {});
plugin.registerAPICall(
'get', 'get',
'/embark-api/profiler/:contractName', '/embark-api/profiler/:contractName',
(req, res) => { (req, res) => {
let contractName = req.params.contractName; let contractName = req.params.contractName;
self.profileJSON(contractName, (err, table) => { this.profileJSON(contractName, (err, table) => {
if (err) { if (err) {
return res.send({error: err.message}); return res.send({error: err.message});
} }

View File

@ -141,19 +141,17 @@ class Swarm {
} }
registerConsoleCommands() { registerConsoleCommands() {
const self = this; this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { matches: ['log swarm on'],
return { process: (cmd, callback) => {
match: () => cmd === 'log swarm on', this.events.request('logs:swarm:turnOn', callback);
process: (cb) => self.events.request('logs:swarm:turnOn', cb) }
};
}); });
this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { matches: ['log swarm off'],
return { process: (cmd, callback) => {
match: () => cmd === 'log swarm off', this.events.request('logs:swarm:turnOff', callback);
process: (cb) => self.events.request('logs:swarm:turnOff', cb) }
};
}); });
} }

View File

@ -125,40 +125,42 @@ class WebServer {
} }
registerConsoleCommands() { registerConsoleCommands() {
const self = this; this.embark.registerConsoleCommand({
self.embark.registerConsoleCommand((cmd, _options) => { usage: "webserver start/stop",
return { description: __("Start or stop the websever"),
match: () => cmd === 'webserver start', matches: ['webserver start'],
process: (cb) => self.events.request('start-webserver', cb) process: (cmd, callback) => {
}; this.events.request('start-webserver', callback);
}
}); });
self.embark.registerConsoleCommand((cmd, _options) => { this.embark.registerConsoleCommand({
return { matches: ['webserver stop'],
match: () => cmd === 'webserver stop', process: (cmd, callback) => {
process: (cb) => self.events.request('stop-webserver', cb) this.events.request('stop-webserver', callback);
}; }
}); });
self.embark.registerConsoleCommand((cmd, _options) => { this.embark.registerConsoleCommand({
return { description: __("Open a browser window at the Dapp's url"),
match: () => cmd === 'browser open', matches: ['browser open'],
process: (cb) => self.events.request('open-browser', cb) process: (cmd, callback) => {
}; this.events.request('open-browser', callback);
}
}); });
self.embark.registerConsoleCommand((cmd, _options) => { this.embark.registerConsoleCommand({
return { matches: ['log webserver on'],
match: () => cmd === 'log webserver on', process: (cmd, callback) => {
process: (cb) => self.events.request('logs:webserver:turnOn', cb) this.events.request('logs:webserver:turnOn', callback);
}; }
}); });
self.embark.registerConsoleCommand((cmd, _options) => { this.embark.registerConsoleCommand({
return { matches: ['log webserver off'],
match: () => cmd === 'log webserver off', process: (cmd, callback) => {
process: (cb) => self.events.request('logs:webserver:turnOff', cb) this.events.request('logs:webserver:turnOff', callback);
}; }
}); });
} }

View File

@ -28,12 +28,12 @@ module.exports = function (embark) {
cb(); cb();
}); });
embark.registerConsoleCommand((cmd) => { embark.registerConsoleCommand({
if (cmd === "hello") { matches: ["hello"],
return "hello there!"; description: 'Says Hello',
process: (cmd, callback) => {
callback(null, 'Hello there');
} }
// continue to embark or next plugin;
return false;
}); });
embark.events.on("contractsDeployed", function() { embark.events.on("contractsDeployed", function() {