Skip to content

MokitaNetwork/aetool

Repository files navigation

aetool

Assorted dev tools for working with the aeth blockchain.

Installation

make install

Initialization: aetool testnet

Note: The current mainnet version of aeth is v0.16.0. To start a local testnet with the current mainnet version use --aeth.configTemplate v0.16. To start a local testnet with the latest unreleased version, use --aeth configTemplate master

Option 1:

The aetool testnet bootstrap command starts a local Kava blockchain as a background docker container called generated_aethnode_1. The bootstrap command only starts the Kava blockchain and Kava REST server services.

# Start new testnet
aetool testnet bootstrap --aeth.configTemplate master

Option 2:

To generate a testnet for aeth, binance chain, and a deputy that relays swaps between them:

# Generate a new aetool configuration based off template files
aetool testnet gen-config aeth binance deputy --aeth.configTemplate master

# Pull latest docker images. Docker must be running.
cd ./full_configs/generated && docker-compose pull

# start the testnet
aetool testnet up

# When finished with usage, shut down the processes
aetool testnet down

Flags

Additional flags can be added when initializing a testnet to add additional services:

--ibc: Run Kava testnet with an additional IBC chain

Example:

# Run Kava testnet with an additional IBC chain
aetool testnet bootstrap --aeth.configTemplate master --ibc

--geth: Run a go-ethereum node alongside the Kava testnet. The geth node is initialized with the Kava Bridge contract and test ERC20 tokens. The Kava EVM also includes Multicall contracts deployed. The contract addresses can be found on the Kava-Labs/aeth-bridge README.

Example:

# Run the testnet with a geth node in parallel
aetool testnet bootstrap --aeth.configTemplate master --geth

Geth node ports are not default, as the Kava EVM will use default JSON-RPC ports:

Kava EVM RPC Ports:

  • HTTP JSON-RPC: 8545
  • WS-RPC port: 8546

Geth RPC Ports:

  • HTTP JSON-RPC: 8555
  • WS-RPC port: 8556

To connect to the associated Ethereum wallet with Metamask, setup a new network with the following parameters:

  • New RPC URL: http://localhost:8555
  • Chain ID: 88881 (configured from the genesis)
  • Currency Symbol: ETH

Finally, connect the mining account by importing the JSON config in this directory with this password.

Usage: aetool testnet

REST APIs for both blockchains are exposed on localhost:

You can also interact with the blockchain using the aeth command line. In a new terminal window, set up an alias to aeth on the dockerized aeth node and use it to send a query.

# Add an alias to the dockerized aeth cli
alias daeth='docker exec -it generated_aethnode_1 aeth'

# Confirm that the alias has been added
alias aeth

# For versions before v0.16.x
alias dkvcli='docker exec -it generated_aethnode_1 kvcli'

You can test the set up and alias by executing a sample query:

daeth status
daeth q cdp params

To send transactions you'll need to recover a user account in the dockerized environment. Valid mnemonics for the blockchains be found in the config/common/addresses.yaml file.

# Recover user account
daeth keys add user --recover
# Enter mnemonic
arrive guide way exit polar print kitchen hair series custom siege afraid shrug crew fashion mind script divorce pattern trust project regular robust safe

Test transaction sending by transferring some coins to yourself.

# Query the recovered account's address
daeth keys show user -a
# Send yourself some coins by creating a send transaction with your address as both sender and receiver
daeth tx bank send [user-address] [user-address] 1000000uaeth --from user
# Enter 'y' to confirm the transaction
confirm transaction before signing and broadcasting [y/N]:

# Check transaction result by tx hash
daeth q tx [tx-hash]

Shut down: aetool testnet

When you're done make sure to shut down the aetool testnet. Always shut down the aetool testnets before pulling the latest image from docker, otherwise you may experience errors.

aetool testnet down

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 72.6%
  • JavaScript 14.5%
  • Shell 12.0%
  • Other 0.9%