# Useful commands

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

## 🔑 Key management

#### Add new key

```bash
archwayd keys add wallet
```

#### Recover existing key

```bash
archwayd keys add wallet --recover
```

#### List all keys

```bash
archwayd keys list
```

#### Delete key

```bash
archwayd keys delete wallet
```

#### Export key to the file

```bash
archwayd keys export wallet
```

#### Import key from the file

```bash
archwayd keys import wallet wallet.backup
```

#### Query wallet balance

```bash
archwayd q bank balances $(archwayd 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
archwayd tx staking create-validator \
--amount 1000000aconst \
--pubkey $(archwayd tendermint show-validator) \
--moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id constantine-3 \
--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 1000000000000aconst \
-y
```

#### Edit existing validator

```bash
archwayd tx staking edit-validator \
--new-moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id constantine-3 \
--commission-rate 0.05 \
--from wallet \
--gas-adjustment 1.4 \
--gas auto \
--gas-prices 1000000000000aconst \
-y
```

#### Unjail validator

```bash
archwayd tx slashing unjail --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Jail reason

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

#### List all active validators

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

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

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

## 💲 Token management

#### Withdraw rewards from all validators

```bash
archwayd tx distribution withdraw-all-rewards --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Withdraw commission and rewards from your validator

```bash
archwayd tx distribution withdraw-rewards $(archwayd keys show wallet --bech val -a) --commission --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Delegate tokens to yourself

```bash
archwayd tx staking delegate $(archwayd keys show wallet --bech val -a) 1000000aconst --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Delegate tokens to validator

```bash
archwayd tx staking delegate <TO_VALOPER_ADDRESS> 1000000aconst --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Redelegate tokens to another validator

```bash
archwayd tx staking redelegate $(archwayd keys show wallet --bech val -a) <TO_VALOPER_ADDRESS> 1000000aconst --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Unbond tokens from your validator

```bash
archwayd tx staking unbond $(archwayd keys show wallet --bech val -a) 1000000aconst --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Send tokens to the wallet

```bash
archwayd tx bank send wallet <TO_WALLET_ADDRESS> 1000000aconst --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

## 🗳 Governance

#### List all proposals

```bash
archwayd query gov proposals
```

#### View proposal by id

```bash
archwayd query gov proposal 1
```

#### Vote 'Yes'

```bash
archwayd tx gov vote 1 yes --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Vote 'No'

```bash
archwayd tx gov vote 1 no --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Vote 'Abstain'

```bash
archwayd tx gov vote 1 abstain --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

#### Vote 'NoWithVeto'

```bash
archwayd tx gov vote 1 NoWithVeto --from wallet --chain-id constantine-3 --gas-adjustment 1.4 --gas auto --gas-prices 1000000000000aconst -y
```

## ⚡️ Utility

#### Update ports

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

#### Update Indexer

**Disable indexer**

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

**Enable indexer**

```bash
sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.archway/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/.archway/config/app.toml
```

## 🚨 Maintenance

#### Get validator info

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

#### Get sync info

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

#### Get node peer

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

#### Check if validator key is correct

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

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

#### Set minimum gas price

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

#### Enable prometheus

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

#### Reset chain data

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

#### 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 archwayd
sudo systemctl disable archwayd
sudo rm /etc/systemd/system/archwayd.service
sudo systemctl daemon-reload
rm -f $(which archwayd)
rm -rf $HOME/.archway
rm -rf $HOME/archway
```

## ⚙️ Service Management

#### Reload service configuration

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

#### Enable service

```bash
sudo systemctl enable archwayd
```

#### Disable service

```bash
sudo systemctl disable archwayd
```

#### Start service

```bash
sudo systemctl start archwayd
```

#### Stop service

```bash
sudo systemctl stop archwayd
```

#### Restart service

```bash
sudo systemctl restart archwayd
```

#### Check service status

```bash
sudo systemctl status archwayd
```

#### Check service logs

```bash
sudo journalctl -u archwayd -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/testnet/archway/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.
