# Useful commands

### 🔑 Key management <a href="#key-management" id="key-management"></a>

**ADD NEW KEY**

```
uniond keys add wallet
```

**RECOVER EXISTING KEY**

```
uniond keys add wallet --recover
```

**LIST ALL KEYS**

```
uniond keys list
```

**DELETE KEY**

```
uniond keys delete wallet
```

**EXPORT KEY TO A FILE**

```
uniond keys export wallet
```

**IMPORT KEY FROM A FILE**

```
uniond keys import wallet wallet.backup
```

**QUERY WALLET BALANCE**

```
uniond q bank balances $(uniond keys show wallet -a)
```

### 👷 Validator management <a href="#validator-management" id="validator-management"></a>

To create validator please refer to [official documentation](https://union.build/docs/joining-testnet/creating-validators/)

**UNJAIL VALIDATOR**

```
uniond tx slashing unjail --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**JAIL REASON**

```
uniond query slashing signing-info $(uniond tendermint show-validator)
```

**LIST ALL ACTIVE VALIDATORS**

```
uniond q staking validators -oj --limit=3000 | jq '.validators[] | select(.status=="BOND_STATUS_BONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " \t " + .description.moniker' | sort -gr | nl
```

**LIST ALL INACTIVE VALIDATORS**

```
uniond q staking validators -oj --limit=3000 | jq '.validators[] | select(.status=="BOND_STATUS_UNBONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " \t " + .description.moniker' | sort -gr | nl
```

**VIEW VALIDATOR DETAILS**

```
uniond q staking validator $(uniond keys show wallet --bech val -a)
```

### 💲 Token management <a href="#token-management" id="token-management"></a>

**WITHDRAW REWARDS FROM ALL VALIDATORS**

```
uniond tx distribution withdraw-all-rewards --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**WITHDRAW COMMISSION AND REWARDS FROM YOUR VALIDATOR**

```
uniond tx distribution withdraw-rewards $(uniond keys show wallet --bech val -a) --commission --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**DELEGATE TOKENS TO YOURSELF**

```
uniond tx staking delegate $(uniond keys show wallet --bech val -a) 1000000muno --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**DELEGATE TOKENS TO VALIDATOR**

```
uniond tx staking delegate <TO_VALOPER_ADDRESS> 1000000muno --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**REDELEGATE TOKENS TO ANOTHER VALIDATOR**

```
uniond tx staking redelegate $(uniond keys show wallet --bech val -a) <TO_VALOPER_ADDRESS> 1000000muno --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**UNBOND TOKENS FROM YOUR VALIDATOR**

```
uniond tx staking unbond $(uniond keys show wallet --bech val -a) 1000000muno --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**SEND TOKENS TO THE WALLET**

```
uniond tx bank send wallet <TO_WALLET_ADDRESS> 1000000muno --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

### 🗳 Governance <a href="#governance" id="governance"></a>

**LIST ALL PROPOSALS**

```
uniond query gov proposals
```

**VIEW PROPOSAL BY ID**

```
uniond query gov proposal 1
```

**VOTE ‘YES’**

```
uniond tx gov vote 1 yes --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**VOTE ‘NO’**

```
uniond tx gov vote 1 no --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**VOTE ‘ABSTAIN’**

```
uniond tx gov vote 1 abstain --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

**VOTE ‘NOWITHVETO’**

```
uniond tx gov vote 1 NoWithVeto --from wallet --chain-id union-testnet-8 --gas-adjustment 1.4 --gas auto --gas-prices 0muno -y
```

### ⚡️ Utility <a href="#utility" id="utility"></a>

**UPDATE PORTS**

```
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/.union/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/.union/config/app.toml
```

**UPDATE INDEXER**

**Disable indexer**

```
sed -i -e 's|^indexer *=.*|indexer = "null"|' $HOME/.union/config/config.toml
```

**Enable indexer**

```
sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.union/config/config.toml
```

**UPDATE PRUNING**

```
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/.union/config/app.toml
```

### 🚨 Maintenance <a href="#maintenance" id="maintenance"></a>

**GET VALIDATOR INFO**

```
uniond status 2>&1 | jq .ValidatorInfo
```

**GET SYNC INFO**

```
uniond status 2>&1 | jq .SyncInfo
```

**GET NODE PEER**

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

**CHECK IF VALIDATOR KEY IS CORRECT**

```
[[ $(uniond q staking validator $(uniond keys show wallet --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(uniond 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 http://localhost:17157/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 = \"0muno\"/" $HOME/.union/config/app.toml
```

**ENABLE PROMETHEUS**

```
sed -i -e "s/prometheus = false/prometheus = true/" $HOME/.union/config/config.toml
```

**RESET CHAIN DATA**

```
uniond tendermint unsafe-reset-all --keep-addr-book --home $HOME/.union --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**!

```
cd $HOME
sudo systemctl stop union.service
sudo systemctl disable union.service
sudo rm /etc/systemd/system/union.service
sudo systemctl daemon-reload
rm -f $(which uniond)
rm -rf $HOME/.union
```

### ⚙️ Service Management <a href="#service-management" id="service-management"></a>

**RELOAD SERVICE CONFIGURATION**

```
sudo systemctl daemon-reload
```

**ENABLE SERVICE**

```
sudo systemctl enable union.service
```

**DISABLE SERVICE**

```
sudo systemctl disable union.service
```

**START SERVICE**

```
sudo systemctl start union.service
```

**STOP SERVICE**

```
sudo systemctl stop union.service
```

**RESTART SERVICE**

```
sudo systemctl restart union.service
```

**CHECK SERVICE STATUS**

```
sudo systemctl status union.service
```

**CHECK SERVICE LOGS**

```
sudo journalctl -u union.service -f --no-hostname -o cat
```


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://service.coinhunterstr.com/testnet/union/testnet-8/useful-commands.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
