Skip to main content

CLI Cheatsheet

Chain ID: nillion-1 | Current Node Version: v0.2.5

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

nilliond keys add KEY

Recover key (via existing mnemonic)

nilliond keys add KEY --recover

List all keys

nilliond keys list

Delete key

nilliond keys delete KEY

Wallet

Wallet balance

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

Send

nilliond tx bank send YOUR_KEY RECEIVER_ADDRESS 1000000unil \
--chain-id nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--from KEY

Withdraw rewards from all validators

nilliond tx distribution withdraw-all-rewards \
--chain-id nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--from KEY

Withdraw Rewards including Commission

nilliond tx distribution withdraw-rewards VALIDATOR_ADRESS \
--commission \
--chain-id nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--from KEY

Delegate tokens to yourself

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

Delegate tokens to validator

nilliond tx staking delegate VALIDATOR_ADDRESS 1000000unil \
--chain-id nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--from KEY

Redelegate tokens to another validator

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

Unbond tokens from your validator

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

Governance

List of all proposals

nilliond query gov proposals --node https://nillion-rpc.noders.services:443

Check vote

nilliond query gov proposal PROPOSAL_NUMBER \
--chain-id nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--output json | jq

Vote

Vote options:

  • yes
  • no
  • no_with_veto
  • abstain
nilliond tx gov vote PROPOSAL_NUMBER VOTE_OPTION \
--chain-id nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--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.

nilliond tx staking create-validator \
--amount 1000000unil \
--commission-max-change-rate "0.05" \
--commission-max-rate "0.10" \
--commission-rate "0.05" \
--min-self-delegation "1" \
--pubkey=$(nilliond 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 nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--from KEY

Edit validator

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

Unjail

nilliond tx slashing unjail \
--chain-id nillion-1 \
--node https://nillion-rpc.noders.services:443 --fees 3000unil \
--from KEY

Jail reason

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

Validator details

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

Maintenance

Get validator info

nilliond status 2>&1 | jq .ValidatorInfo

Get sync info

nilliond status 2>&1 | jq .SyncInfo

Get node peer

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

Check if validator key is correct

[[ $(nilliond q staking validator $(nilliond keys show KEY --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(nilliond 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://nillion-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.001unil\"/" ~/.nilliond/config/app.toml

###Enable prometheus

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

Reset chain data

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

Service Management

Reload service configuration

sudo systemctl daemon-reload

Enable service

sudo systemctl enable nilliond

Disable service

sudo systemctl disable nilliond

Start service

sudo systemctl start nilliond

Stop service

sudo systemctl stop nilliond

Restart service

sudo systemctl restart nilliond

Check service status

sudo systemctl status nilliond

Check service logs

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

Remove node

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