Skip to content

Latest commit

 

History

History
75 lines (48 loc) · 3.45 KB

README.md

File metadata and controls

75 lines (48 loc) · 3.45 KB

arc.js-scripts

Scripts that run against @daostack/arc.js

Installation

Clone or fork the arc.js-scripts repository from GitHub, then:

npm run build

Run a Script

  1. Create a JavaScript file that exports a method that returns a promise that it is complete. When arc.js-scripts runs your script, the method will be invoked with two parameters: web3 and the name of the network in lowercase.

    Two globals will also be made available: web3 and accounts.

    See scripts/example.ts for an example of a script.

    Note that npm run build transpiles example.ts into the required JavaScript, putting the generated JavaScript in the "build/scripts" directory.

    When you refer to the script on the command line (see below), you must refer to a JavaScript file, not to TypeScript.

  2. Run the script

    Get help on command line options:

    node ./build/scripts/arcScript.js -h

    Run the example script against a local node with default url and port:

    node ./build/scripts/arcScript.js -s ./example.js

Use truffle-hdwallet-provider

If you want to use the truffle-hdwallet-provider rather than a local node then you must supply the provider option:

node ./build/scripts/arcScript.js -p '[pathToConfig]'

The path should reference a json file containing a truffle-hdwallet-provider configuration, looking something like this:

  {
    "mnemonic": "...",
    "providerUrl": "https://kovan.infura.io/..."
  }

Notes

  • Your method may call InitializeArcJs for cases where you want to use Arc contracts (see scripts/example.ts).

  • TypeScript is not necessary, you can create your JavaScript script files however you want. But if you want you can easily create scripts using TypeScript by placing your .ts files anywhere under the project root folder and running npm run build to compile them. The generated JavaScript will appear in the "build" folder. Suppose you put your typescript files in another folder called "local_scripts" in the project root. Then after running npm run build you can run your script like this:

    node ./build/scripts/arcScript.js -s ../local_scripts/[yourscript].js

  • If you are using truffle-hdwallet-provider and you run a script and it connects to the provider but then returns without executing your script, make sure that a node is listening on the url you provided in your provider configuration file.

  • The default name of the method that will be executed is "run". You may use a different method name and specify it on the command line using the "method" parameter.

  • The "scripts" directory contains some useful scripts that you can use, for example:

    Script Purpose
    accountLists list all of the accounts known to the current web3
    contractNew instantiate an Arc contract given its name and contructor parameters in json
    daoCreate create a DAO given a json spec for the DAO
    daoParticipantsList list participants in the given DAO, by reputation
    daoSchemesList list the schemes registered with the given DAO
    ethTransfer transfer ETH from one account to another
    proposalVote cast a vote on the given proposal with the given voting machine
    proposalGpStake stake on a vote on the given proposal with the given GenesisProtocol
    tokenTransfer transfer tokens from one account to another
    tokenMint mint tokens to an account