Add a general purpose contract CLI
This allows to call any method on any contract using the CLI. for example: $ truffle exec scripts/cli.js Operator proposalsCount
This commit is contained in:
parent
7d52161014
commit
d42b0fa2dd
11
README.mdown
11
README.mdown
@ -68,6 +68,17 @@ At some point these should be moved into a real nice CLI.
|
|||||||
|
|
||||||
To run these scripts use `truffle exec`. For example: `truffle exec scripts/add-proposal.js`
|
To run these scripts use `truffle exec`. For example: `truffle exec scripts/add-proposal.js`
|
||||||
|
|
||||||
|
### cli.js
|
||||||
|
|
||||||
|
Call any function on any contract:
|
||||||
|
|
||||||
|
$ truffle exec scripts/cli.js <Contract Name> <Function> [<optional> <arguments>]
|
||||||
|
|
||||||
|
For example:
|
||||||
|
$ truffle exec scripts/cli.js Operator proposalsCount
|
||||||
|
|
||||||
|
Please note that the contract name and the function are case sensitive.
|
||||||
|
|
||||||
### add-contributor.js
|
### add-contributor.js
|
||||||
Adds a new core contributor, creates a proposal for the new contributor and votes for that one.
|
Adds a new core contributor, creates a proposal for the new contributor and votes for that one.
|
||||||
|
|
||||||
|
34
scripts/cli.js
Normal file
34
scripts/cli.js
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
module.exports = function(callback) {
|
||||||
|
const Registry = artifacts.require('./Registry.sol');
|
||||||
|
Registry.deployed().then(async (registry) => {
|
||||||
|
let contractName = process.argv[4];
|
||||||
|
let method = process.argv[5];
|
||||||
|
let args = process.argv.slice(6);
|
||||||
|
|
||||||
|
if(!contractName) {
|
||||||
|
console.log("Usage:")
|
||||||
|
console.log(" truffle exec scripts/cli.js <Contract name> <method to call> [<optional> <arguments>]");
|
||||||
|
callback();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let contractAddress = await registry.getProxyFor(contractName);
|
||||||
|
console.log(`Using ${contractName} at ${contractAddress}`);
|
||||||
|
let contract = await artifacts.require(`./${contractName}`).at(contractAddress);
|
||||||
|
|
||||||
|
console.log(`Calling ${method} with ${JSON.stringify(args)}`);
|
||||||
|
|
||||||
|
contract[method](...args).then((result) => {
|
||||||
|
console.log('Result:');
|
||||||
|
console.log(result);
|
||||||
|
|
||||||
|
callback();
|
||||||
|
}).catch((error) => {
|
||||||
|
console.log("Call failed. Probably the contract raised an error?\n");
|
||||||
|
console.log("...");
|
||||||
|
callback(error);
|
||||||
|
});
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user