πŸ› οΈUseful commands

Transactions and curl commands are launched while the node is running

If transactions are not sent with an error account sequence mismatch, expected 18, got 17: incorrect account sequence, then add the -s 18 switch to the command (replace the number with the one waiting for sequence)

First we set the variables

BINARY="canined"
DENOM="ujkl"
FOLDER=".canine"

Working with wallets

# create wallet
$BINARY keys add <name_wallet> --keyring-backend os

# restore wallet
$BINARY keys add <name_wallet> --recover --keyring-backend os

# restore wallet for EVM networks
$BINARY keys add <name_wallet> --recover --coin-type 118 --algo secp256k1

# list wallets
$BINARY keys list

# show account key
$BINARY keys show <name_wallet> --bech acc

# show validator key
$BINARY keys show <name_wallet> --bech val

# show consensus key
$BINARY keys show <name_wallet> --bech cons

# show all supported addresses
$BINARY debug addr <wallet_addr>

# how private key
$BINARY keys export <name_wallet> --unarmored-hex --unsafe

# account request
$BINARY q auth account $($BINARY keys show <name_wallet> -a) -o text

# delete wallet
$BINARY keys delete <name_wallet>

General information

# check blocks
$BINARY status 2>&1 | jq ."SyncInfo"."latest_block_height"

# check logs
journalctl -u $BINARY -f -o cat

# check status
curl localhost:26657/status

# check balance
$BINARY q bank balances <address>

# check the pubkey of the validator
$BINARY tendermint show-validator

# check the validator
$BINARY query staking validator <valoper_address>
$BINARY query staking validators --limit 1000000 -o json | jq '.validators[] | select(.description.moniker=="<name_moniker>")' | jq

# check TX_HASH
$BINARY query tx <TX_HASH>

# network settings
$BINARY q staking params
$BINARY q slashing params

# check how many blocks are skipped by the validator
$BINARY q slashing signing-info $($BINARY tendermint show-validator)

# find out the validator creation transaction (replace your valoper_address)
$BINARY query txs --events='create_validator.validator=<your_valoper_address>' -o=json | jq .txs[0].txhash -r

# view active set
$BINARY q staking validators -o json --limit=1000 \
| jq '.validators[] | select(.status=="BOND_STATUS_BONDED")' \
| jq -r '.tokens + " - " + .description.moniker' \
| sort -gr | nl

# viewing an inactive set
$BINARY q staking validators -o json --limit=1000 \
| jq '.validators[] | select(.status=="BOND_STATUS_UNBONDED")' \
| jq -r '.tokens + " - " + .description.moniker' \
| sort -gr | nl

Transactions

# collect rewards from all validators delegated to (no validator fee)
$BINARY tx distribution withdraw-all-rewards --from <name_wallet> --fees 5000$DENOM -y

# collect rewards from a separate validator or rewards + commission from your own validator
$BINARY tx distribution withdraw-rewards <valoper_address> --from <name_wallet> --fees 5000$DENOM --commission -y

# delegate more to your stake (this is how 1 coin is sent)
$BINARY tx staking delegate <valoper_address> 1000000$DENOM --from <name_wallet> --fees 5000$DENOM -y

# redelegation to another validator
$BINARY tx staking redelegate <src-validator-addr> <dst-validator-addr> 1000000$DENOM --from <name_wallet> --fees 5000$DENOM -y

# unbond 
$BINARY tx staking unbond <addr_valoper> 1000000$DENOM --from <name_wallet> --fees 5000$DENOM -y

# send coins to another address
$BINARY tx bank send <name_wallet> <address> 1000000$DENOM --fees 5000$DENOM -y

# get out of jail
$BINARY tx slashing unjail --from <name_wallet> --fees 5000$DENOM -y

Governance

# list proposals
$BINARY q gov proposals

# see the result of the vote
$BINARY q gov proposals --voter <ADDRESS>

# vote for the proposal
$BINARY tx gov vote 1 yes --from <name_wallet> --fees 555$DENOM

# make a deposit to the proposal
$BINARY tx gov deposit 1 1000000$DENOM --from <name_wallet> --fees 555$DENOM

# create an proposal
$BINARY tx gov submit-proposal --title="Randomly reward" --description="Reward 10 testnet participants who completed more than 3 tasks" --type="Text" --deposit="11000000$DENOM" --from=<name_wallet> --fees 500$DENOM

Peers and RPC

# find out your peer
PORTR=$(grep -A 3 "\[p2p\]" ~/$FOLDER/config/config.toml | egrep -o ":[0-9]+") && \
echo $($BINARY tendermint show-node-id)@$(curl ifconfig.me)$PORTR

# find out RPC port
echo -e "\033[0;32m$(grep -A 3 "\[rpc\]" ~/$FOLDER/config/config.toml | egrep -o ":[0-9]+")\033[0m"

# checking the number of peers
PORT=
curl -s http://localhost:$PORT/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr | split(":")[2])"' | wc -l

# list of monikers of connected peers
curl -s http://localhost:$PORT/net_info | jq '.result.peers[].node_info.moniker'

# ΠŸΡ€ΠΎΠ²Π΅Ρ€ΠΊΠ° prevotes/precommits
curl -s localhost:$PORT/consensus_state | jq '.result.round_state.height_vote_set[0].prevotes_bit_array' && \
curl -s localhost:$PORT/consensus_state | jq '.result.round_state.height_vote_set[0].precommits_bit_array'

# check prevote of your validator
curl -s localhost:$PORT/consensus_state -s | grep $(curl -s localhost:26657/status | jq -r .result.validator_info.address[:12])

Last updated