Skip to main content

CLI Cheatsheet

Chain ID: humans_1089-1 | Current Node Version: v1.0.0

This cheatsheet collects commonly used CLI commands for node operators to easily copy and paste. A few conventions we follow:

  • Capitalized words indicate placeholders
  • Always use our own [NODERS]TEAM RPC endpoints
  • Always specify --chain-id and --node flags even when they are unnecessary
  • Query CLI command always uses --output json flag and pipes result through jq

Wallet generate and recover

Add new key

humansd keys add KEY

Recover key (via existing mnemonic)

humansd keys add KEY --recover

List all keys

humansd keys list

Delete key

humansd keys delete KEY

Wallet

Wallet balance

humansd q bank balances $(humansd keys show KEY -a) --node https://humans-rpc.noders.services:443

Send

humansd tx bank send YOUR_KEY RECEIVER_ADDRESS 1000000aheart \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Withdraw rewards from all validators

humansd tx distribution withdraw-all-rewards \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Withdraw Rewards including Commission

humansd tx distribution withdraw-rewards VALIDATOR_ADRESS \
--commission \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Delegate tokens to yourself

humansd tx staking delegate $(humansd keys show KEY --bech val -a) 1000000aheart \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Delegate tokens to validator

humansd tx staking delegate VALIDATOR_ADDRESS 1000000aheart \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Redelegate tokens to another validator

humansd tx staking redelegate $(humansd keys show KEY --bech val -a) VALIDATOR_ADDRESS 1000000aheart \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Unbond tokens from your validator

humansd tx staking unbond $(humansd keys show KEY --bech val -a) aheart \
--chain-id andromeda-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Governance

List of all proposals

humansd query gov proposals --node https://humans-rpc.noders.services:443

Check vote

humansd query gov proposal PROPOSAL_NUMBER \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--output json | jq

Vote

Vote options:

  • yes
  • no
  • no_with_veto
  • abstain
humansd tx gov vote PROPOSAL_NUMBER VOTE_OPTION \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Validator management

Create Validator

note

We use example filed values instead of capitalized dummy words for demo purpose in this command. Please make sure to adjust accordingly for your use.

humansd tx staking create-validator \
--amount 1000000aheart \
--commission-max-change-rate "0.05" \
--commission-max-rate "0.10" \
--commission-rate "0.05" \
--min-self-delegation "1" \
--pubkey=$(humansd tendermint show-validator) \
--moniker '[NODERS]TEAM SERVICE' \
--website "https://noders.team" \
--identity "220491ADDD660741" \
--details "Trusted blockchain validator and web3 developer team" \
--security-contact="office@noders.team" \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Edit validator

humansd tx staking edit-validator \
--new-moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id humans_1089-1 \
--commission-rate 0.05 \
--from KEY \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \

Unjail

humansd tx slashing unjail \
--chain-id humans_1089-1 \
--node https://humans-rpc.noders.services:443 --fees 3000aheart \
--from KEY

Jail reason

humansd query slashing signing-info $(humansd tendermint show-validator)

Validator details

humansd q staking validator $(humansd keys show KEY --bech val -a)

Maintenance

Get validator info

humansd status 2>&1 | jq .ValidatorInfo

Get sync info

humansd status 2>&1 | jq .SyncInfo

Get node peer

echo $(humansd tendermint show-node-id)'@'$(curl -s ifconfig.me)':'$(cat ~/.humansd/config/config.toml | sed -n '/Address to listen for incoming connection/{n;p;}' | sed 's/.*://; s/".*//')

Check if validator key is correct

[[ $(humansd q staking validator $(humansd keys show KEY --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(humansd status | jq -r .ValidatorInfo.PubKey.value) ]] && echo -e "\n\e[1m\e[32mTrue\e[0m\n" || echo -e "\n\e[1m\e[31mFalse\e[0m\n"

Get live peers

curl -sS https://humans-rpc.noders.services:443/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'

Set minimum gas price

sed -i -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"0.001aheart\"/" ~/.humansd/config/app.toml

###Enable prometheus

sed -i -e "s/prometheus = false/prometheus = true/" ~/.humansd/config/config.toml

Reset chain data

humansd tendermint unsafe-reset-all --keep-addr-book --home ~/.humansd

Service Management

Reload service configuration

sudo systemctl daemon-reload

Enable service

sudo systemctl enable humansd

Disable service

sudo systemctl disable humansd

Start service

sudo systemctl start humansd

Stop service

sudo systemctl stop humansd

Restart service

sudo systemctl restart humansd

Check service status

sudo systemctl status humansd

Check service logs

sudo journalctl -u humansd -f --no-hostname -o cat

Remove node

cd $HOME
sudo systemctl stop humansd
sudo systemctl disable humansd
sudo rm /etc/systemd/system/humansd.service
sudo systemctl daemon-reload
rm -f $(which humansd)
rm -rf ~/.humansd
rm -rf $HOME/humansdotai