# Useful commands

<figure><img src="https://github.com/takeshi-val/Logo/raw/main/althea.png" alt=""><figcaption></figcaption></figure>

## 🔑 Key management

#### Add new key

```bash
althea keys add wallet
```

#### Recover existing key

```bash
althea keys add wallet --recover
```

#### List all keys

```bash
althea keys list
```

#### Delete key

```bash
althea keys delete wallet
```

#### Export key to the file

```bash
althea keys export wallet
```

#### Import key from the file

```bash
althea keys import wallet wallet.backup
```

#### Query wallet balance

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

## 👷 Validator management

{% hint style="info" %}
Please make sure you have adjusted **moniker**, **identity**, **details** and **website** to match your values.
{% endhint %}

#### Create new validator

```bash
althea tx staking create-validator \
--amount 1000000ualthea \
--pubkey $(althea tendermint show-validator) \
--moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id althea_7357-1 \
--commission-rate 0.05 \
--commission-max-rate 0.20 \
--commission-max-change-rate 0.01 \
--min-self-delegation 1 \
--from wallet \
--gas-adjustment 1.4 \
--gas auto \
--gas-prices 0ualthea \
-y
```

#### Edit existing validator

```bash
althea tx staking edit-validator \
--new-moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id althea_7357-1 \
--commission-rate 0.05 \
--from wallet \
--gas-adjustment 1.4 \
--gas auto \
--gas-prices 0ualthea \
-y
```

#### Unjail validator

{% code overflow="wrap" %}

```bash
althea tx slashing unjail --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Jail reason

{% code overflow="wrap" %}

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

{% endcode %}

#### List all active validators

{% code overflow="wrap" %}

```bash
althea 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
```

{% endcode %}

#### List all inactive validators

{% code overflow="wrap" %}

```bash
althea 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
```

{% endcode %}

#### View validator details

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

## 💲 Token management

#### Withdraw rewards from all validators

{% code overflow="wrap" %}

```bash
althea tx distribution withdraw-all-rewards --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Withdraw commission and rewards from your validator

{% code overflow="wrap" %}

```bash
althea tx distribution withdraw-rewards $(althea keys show wallet --bech val -a) --commission --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Delegate tokens to yourself

{% code overflow="wrap" %}

```bash
althea tx staking delegate $(althea keys show wallet --bech val -a) 1000000ualthea --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Delegate tokens to validator

{% code overflow="wrap" %}

```bash
althea tx staking delegate <TO_VALOPER_ADDRESS> 1000000ualthea --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Redelegate tokens to another validator

{% code overflow="wrap" %}

```bash
althea tx staking redelegate $(althea keys show wallet --bech val -a) <TO_VALOPER_ADDRESS> 1000000ualthea --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Unbond tokens from your validator

{% code overflow="wrap" %}

```bash
althea tx staking unbond $(althea keys show wallet --bech val -a) 1000000ualthea --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Send tokens to the wallet

{% code overflow="wrap" %}

```bash
althea tx bank send wallet <TO_WALLET_ADDRESS> 1000000ualthea --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

## 🗳 Governance

#### List all proposals

```bash
althea query gov proposals
```

#### View proposal by id

```bash
althea query gov proposal 1
```

#### Vote 'Yes'

{% code overflow="wrap" %}

```bash
althea tx gov vote 1 yes --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Vote 'No'

{% code overflow="wrap" %}

```bash
althea tx gov vote 1 no --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Vote 'Abstain'

{% code overflow="wrap" %}

```bash
althea tx gov vote 1 abstain --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

#### Vote 'NoWithVeto'

{% code overflow="wrap" %}

```bash
althea tx gov vote 1 NoWithVeto --from wallet --chain-id althea_7357-1 --gas-adjustment 1.4 --gas auto --gas-prices 0ualthea -y
```

{% endcode %}

## ⚡️ Utility

#### Update ports

{% code overflow="wrap" %}

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

{% endcode %}

#### Update Indexer

**Disable indexer**

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

**Enable indexer**

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

#### Update pruning

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

## 🚨 Maintenance

#### Get validator info

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

#### Get sync info

```bash
althea status 2>&1 | jq .SyncInfo
```

#### Get node peer

{% code overflow="wrap" %}

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

{% endcode %}

#### Check if validator key is correct

{% code overflow="wrap" %}

```bash
[[ $(althea q staking validator $(althea keys show wallet --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(althea 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"
```

{% endcode %}

#### Get live peers

{% code overflow="wrap" %}

```bash
curl -sS http://localhost:15257/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'
```

{% endcode %}

#### Set minimum gas price

{% code overflow="wrap" %}

```bash
sed -i -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"0ualthea\"/" $HOME/.althea/config/app.toml
```

{% endcode %}

#### Enable prometheus

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

#### Reset chain data

{% code overflow="wrap" %}

```bash
althea tendermint unsafe-reset-all --keep-addr-book --home $HOME/.althea --keep-addr-book
```

{% endcode %}

#### Remove node

{% hint style="danger" %}
Please, before proceeding with the next step! All chain data will be lost! Make sure you have backed up your **priv\_validator\_key.json**!
{% endhint %}

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

## ⚙️ Service Management

#### Reload service configuration

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

#### Enable service

```bash
sudo systemctl enable althea
```

#### Disable service

```bash
sudo systemctl disable althea
```

#### Start service

```bash
sudo systemctl start althea
```

#### Stop service

```bash
sudo systemctl stop althea
```

#### Restart service

```bash
sudo systemctl restart althea
```

#### Check service status

```bash
sudo systemctl status althea
```

#### Check service logs

```bash
sudo journalctl -u althea -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.takeshi.team/chain/mainnet/althea/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.
