Hello!
dapptools
is a suite of Ethereum focused CLI tools following the Unix design philosophy,
favoring composability, configurability and extensibility.
This repository contains the source code for several programs hand-crafted and maintained by DappHub, along with dependency management, courtesy of Nix.
dapptools is currently in a stage of clandestine development where support for the casual user may be deprived. The software can now be considered free as in free puppy. Users seeking guidance can explore using foundry as an alternative
Install Nix if you haven't already (instructions). Then install dapptools:
nix profile install github:dapphub/dapptools#{dapp,ethsign,hevm,seth}
Nix will offer to use the dapptools binary cache, which will speed up installs, but requires you to trust both us and the Cachix infrastructure.
curl https://dapp.tools/install | sh
This configures the dapphub binary cache and installs the dapp
, solc
, seth
and hevm
executables.
NOTE: Arm support in the GHC haskell compiler is still fairly bleeding edge, until this
situation stabilises, users of M1 macs must run dapptools (and the installer!) under rosetta 2 (i.e.
as an emulated x86 program). Make sure /etc/nix/nix.conf
contains system = x86_64-darwin
.
You can also install an individual tool with:
nix-env -iA <tool> -f $(curl -sS https://api.github.com/repos/dapphub/dapptools/releases/latest | jq -r .tarball_url)
If you instead want to build from master
, change the url to https://github.com/dapphub/dapptools/archive/master.tar.gz
.
Static binaries for linux and macos of hevm are available for each release at https://github.com/dapphub/dapptools/releases.
Most functionality is available out of the box, but for symbolic execution you will need
solc
and (z3
or cvc4
(or both)).
For more information about the tools, consult the individual README pages:
or use the --help
flag for any tool.
We're also happy to answer any questions at https://dapphub.chat/.
Deploy a 'Hello World' contract and call it:
export ETH_RPC_URL=https://mainnet.infura.io/v3/$YOUR_API_KEY
export ETH_FROM=$YOUR_ADDRESS
echo 'contract Hello { function hi() public pure returns(string memory) {return "Hello, World!";}}' | solc --bin -o . --overwrite -
HELLO=$(seth send --create $(<Hello.bin))
seth call $HELLO "hi()(string)"
Debug the first transaction of the latest block in the interactive debugger:
export ETH_RPC_URL=https://mainnet.infura.io/v3/$YOUR_API_KEY
seth run-tx $(seth block latest transactions | jq .'[0]' -r) --debug
If Vitalik's next transaction were a contract deployment, calculate the address it would be deployed at:
export ETH_RPC_URL=https://mainnet.infura.io/v3/$YOUR_API_KEY
dapp address 0xab5801a7d398351b8be11c439e05c5b3259aec9b $(seth nonce 0xab5801a7d398351b8be11c439e05c5b3259aec9b)
Symbolically explore the possible execution paths of a call to dai.transfer(address,uint)
:
seth bundle-source 0x6b175474e89094c44da98b954eedeac495271d0f > daisrc.json && \
hevm symbolic --address 0x6b175474e89094c44da98b954eedeac495271d0f --rpc $ETH_RPC_URL --debug --sig "transfer(address,uint256)" --json-file daisrc.json
Contributions are always welcome! You may be interested in the architecture of this repository.