# 📜  Useful Commands

***Get validator info***

```bash
kyved status 2>&1 | jq .ValidatorInfo
```

***Get sync info***

```bash
kyved status 2>&1 | jq
```

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

***Add new key***

```bash
kyved keys add wallet
```

***Recover existing key***

```bash
kyved keys add wallet --recover
```

***List all keys***

```bash
kyved keys list
```

***Delete key***

```bash
kyved keys delete wallet
```

***Query wallet balance***

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

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

Please make sure you have adjusted **moniker**, **identity**, **details** and **website** to match your values.

***Create new validator***

```bash
kyved tx staking create-validator \
--amount 10000000000ukyve \
--pubkey=$(kyved tendermint show-validator) \
--moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id kyve-1 \
--commission-rate="0.10" \
--commission-max-rate="0.2" \
--commission-max-change-rate="0.05" \
--min-self-delegation="1" \
--from wallet \
--gas 51000000 \
--fees 1020000ukyve \
-y
```

***Edit existing validator***

```bash
kyved tx staking edit-validator \
--new-moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id kyve-1 \
--commission-rate 0.05 \
--from wallet \
--gas 350000 -y
```

***Unjail validator***

```bash
kyved tx slashing unjail --from wallet --chain-id kyve-1 --gas 350000 -y
```

***Jail reason***

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

***View validator details***

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

### &#x20;*Token management* <a href="#token-management" id="token-management"></a>

***Withdraw rewards from all validators***

```bash
kyved tx distribution withdraw-all-rewards --from wallet --chain-id kyve-1 --gas 350000 -y
```

***Withdraw commission and rewards from your validator***

```bash
kyved tx distribution withdraw-rewards $(kyved keys show wallet --bech val -a) --commission --from wallet --chain-id kyve-1 --gas 350000 -y
```

***Delegate tokens to yourself***

```bash
kyved tx staking delegate $(kyved keys show wallet --bech val -a) 1000000ukyve --from wallet --chain-id kyve-1 --gas 350000 -y
```

***Delegate tokens to validator***

```bash
kyved tx staking delegate <TO_VALOPER_ADDRESS> 1000000ukyve --from wallet --chain-id cataclysm-1 --gas-adjustment 1.4 --gas auto --gas-prices 0.025unibi -y
```

***Redelegate tokens to another validator***

```bash
kyved tx staking redelegate $(kyved keys show wallet --bech val -a) <TO_VALOPER_ADDRESS> 1000000ukyve --from wallet --chain-id kyve-1 --gas 350000 -y
```

***Unbond tokens from your validator***

<pre class="language-bash"><code class="lang-bash"><strong>kyved tx staking unbond $(kyved keys show wallet --bech val -a) 1000000ukyve --from wallet --chain-id kyve-1 --gas 350000 -y
</strong></code></pre>

***Send tokens to the wallet***

```bash
kyved tx bank send wallet <TO_WALLET_ADDRESS> 1000000ukyve --from wallet --chain-id kyve-1 --gas 350000 -y
```

***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**!

```bash
sudo systemctl stop kyved
sudo systemctl disable kyved
rm /etc/systemd/system/kyved.service
sudo systemctl daemon-reload
cd $HOME
rm -rf chain
rm -rf .kyve
rm -rf $(which kyved)
```

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

***Reload service configuration***

```bash
sudo systemctl daemon-reload
```

***Enable service***

```bash
sudo systemctl enable kyved
```

***Disable service***

```bash
sudo systemctl disable kyved
```

***Start service***

```bash
sudo systemctl start kyved
```

***Stop service***

```bash
sudo systemctl stop kyved
```

***Restart service***

```bash
sudo systemctl restart kyved
```

***Check service status***

```bash
sudo systemctl status kyved
```

***Check service logs***

```bash
sudo journalctl -u kyved -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://services.validexis.com/mainnets/kyve/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.
