Key management
Add new key
Copy quicksilverd keys add $WALLET
Recover existing key
Copy quicksilverd keys add $WALLET --recover
List all keys
Copy quicksilverd keys list
Delete key
Copy quicksilverd keys delete $WALLET
Export key to the file
Copy quicksilverd keys export $WALLET
Import key from the file
Copy quicksilverd keys import $WALLET wallet.backup
Query wallet balance
Copy quicksilverd q bank balances $(quicksilverd keys show $WALLET -a)
Validator management
Please make sure you have adjusted moniker , identity and details to match your values.
Create new validator
Copy quicksilverd tx staking create-validator \
--amount 1000000uqck \
--from $WALLET \
--commission-rate 0.1 \
--commission-max-rate 0.2 \
--commission-max-change-rate 0.01 \
--min-self-delegation 1 \
--pubkey $(quicksilverd tendermint show-validator) \
--moniker "YOUR MONIKER" \
--identity "YOUR KEYBASE ID" \
--details "YOUR DETAILS" \
--chain-id rhye-1 \
--fees 100uqck \
-y
Edit existing validator
Copy quicksilverd tx staking edit-validator \
--commission-rate 0.1 \
--new-moniker "YOUR MONIKER" \
--identity "YOUR KEYBASE ID" \
--details "YOUR DETAILS" \
--from $WALLET \
--chain-id rhye-1 \
--fees 100uqck \
-y
Unjail validator
Copy quicksilverd tx slashing unjail --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Jail reason
Copy quicksilverd q slashing signing-info $(quicksilverd tendermint show-validator)
List all active validators
Copy quicksilverd q staking validators -oj --limit=2000 | jq '.validators[] | select(.status=="BOND_STATUS_BONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " " + .description.moniker' | sort -gr | nl
View validator details
Copy quicksilverd q staking validator $(quicksilverd keys show $WALLET --bech val -a)
Token management
Withdraw rewards from all validators
Copy quicksilverd tx distribution withdraw-all-rewards --from $WALLET --chain-id rhye-1 --fees 100uqck
Withdraw commission and rewards from your validator
Copy quicksilverd tx distribution withdraw-rewards $VALOPER_ADDRESS --from $WALLET --commission --chain-id rhye-1 --fees 100uqck -y
Delegate tokens to yourself
Copy quicksilverd tx staking delegate $(quicksilverd keys show $WALLET --bech val -a) 1000000uqck --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Delegate tokens to validator
Copy quicksilverd tx staking delegate YOUR VALOPER ADDRESS 1000000uqck --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Redelegate tokens to another validator
Copy quicksilverd tx staking redelegate $VALOPER_ADDRESS YOUR VALOPER ADDRESS 1000000uqck --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Unbond tokens from your validator
Copy quicksilverd tx staking unbond $(quicksilverd keys show $WALLET --bech val -a) 1000000uqck --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Send tokens to the wallet
Copy quicksilverd tx bank send $WALLET_ADDRESS YOUR WALLET ADDRESS 1000000uqck --fees 100uqck -y
Governance
List all proposals
Copy quicksilverd query gov proposals
View proposal by id
Copy quicksilverd query gov proposal 1
Vote 'Yes'
Copy quicksilverd tx gov vote 1 yes --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Vote 'No'
Copy quicksilverd tx gov vote 1 no --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Vote 'Abstain'
Copy quicksilverd tx gov vote 1 abstain --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Vote 'NoWithVeto'
Copy quicksilverd tx gov vote 1 no_with_veto --from $WALLET --chain-id rhye-1 --fees 100uqck -y
Utility
Update ports
Copy CUSTOM_PORT=110
sed -i -e "s%^proxy_app = \"tcp://127.0.0.1:26658\"%proxy_app = \"tcp://127.0.0.1:${CUSTOM_PORT}58\"%; s%^laddr = \"tcp://127.0.0.1:26657\"%laddr = \"tcp://127.0.0.1:${CUSTOM_PORT}57\"%; s%^pprof_laddr = \"localhost:6060\"%pprof_laddr = \"localhost:${CUSTOM_PORT}60\"%; s%^laddr = \"tcp://0.0.0.0:26656\"%laddr = \"tcp://0.0.0.0:${CUSTOM_PORT}56\"%; s%^prometheus_listen_addr = \":26660\"%prometheus_listen_addr = \":${CUSTOM_PORT}66\"%" $HOME/.quicksilver/config/config.toml
sed -i -e "s%^address = \"tcp://0.0.0.0:1317\"%address = \"tcp://0.0.0.0:${CUSTOM_PORT}17\"%; s%^address = \":8080\"%address = \":${CUSTOM_PORT}80\"%; s%^address = \"0.0.0.0:9090\"%address = \"0.0.0.0:${CUSTOM_PORT}90\"%; s%^address = \"0.0.0.0:9091\"%address = \"0.0.0.0:${CUSTOM_PORT}91\"%" $HOME/.quicksilver/config/app.toml
Update Indexer
Disable indexer
Copy sed -i -e 's|^indexer *=.*|indexer = "null"|' $HOME/.quicksilver/config/config.toml
Enable indexer
Copy sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.quicksilver/config/config.toml
Update pruning
Copy sed -i \
-e 's|^pruning *=.*|pruning = "custom"|' \
-e 's|^pruning-keep-recent *=.*|pruning-keep-recent = "100"|' \
-e 's|^pruning-keep-every *=.*|pruning-keep-every = "0"|' \
-e 's|^pruning-interval *=.*|pruning-interval = "19"|' \
$HOME/.quicksilver/config/app.toml
🚨 Maintenance
Get validator info
Copy quicksilverd status 2>&1 | jq .ValidatorInfo
Get sync info
Copy quicksilverd status 2>&1 | jq .SyncInfo
Get node peer
Copy echo $(quicksilverd tendermint show-node-id)'@'$(curl -s ifconfig.me)':'$(cat $HOME/.sge/config/config.toml | sed -n '/Address to listen for incoming connection/{n;p;}' | sed 's/.*://; s/".*//')
Check if validator key is correct
Copy [[ $(quicksilverd q staking validator $(quicksilverd keys show wallet --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(stchaind 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
Copy curl -sS http://localhost:26657/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'
Reset chain data
Copy quicksilverd tendermint unsafe-reset-all --keep-addr-book --home $HOME/.quicksilver --keep-addr-book
Remove node
Please, before proceeding with the next step! All chain data will be lost! Make sure you have backed up your priv_validator_key.json !
Copy sudo systemctl stop quicksilverd
sudo systemctl disable quicksilverd
sudo rm -rf /etc/systemd/system/quicksilverd.service
sudo rm $(which quicksilverd)
sudo rm -rf $HOME/.quicksilverd
sed -i "/QUICKSILVER_/d" $HOME/.bash_profile
Service Management
Reload service configuration
Copy sudo systemctl daemon-reload
Enable service
Copy sudo systemctl enable quicksilverd
Disable service
Copy sudo systemctl disable quicksilverd
Start service
Copy sudo systemctl start quicksilverd
Stop service
Copy sudo systemctl stop quicksilverd
Restart service
Copy sudo systemctl restart quicksilverd
Check service status
Copy sudo systemctl status quicksilverd
Check service logs
Copy sudo journalctl -u quicksilverd -f --no-hostname -o cat