# Commands

## 📚Useful commands📚

## ⚙️Service

**Info**

```python
blockxd status 2>&1 | jq .NodeInfo
blockxd status 2>&1 | jq .SyncInfo
blockxd status 2>&1 | jq .ValidatorInfo
```

**Check node logs**

```python
sudo journalctl -fu blockxd -o cat
```

**Check service status**

```python
sudo systemctl status blockxd 
```

**Restart service**

```python
sudo systemctl restart blockxd 
```

**Stop service**

```python
sudo systemctl stop blockxd 
```

**Start service**

```python
sudo systemctl start blockxd 
```

**reload/disable/enable**

```python
sudo systemctl daemon-reload
sudo systemctl disable blockxd 
sudo systemctl enable blockxd 
```

**Your Peer**

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

## 🥅Working with keys

**New Key or Recover Key**

```python
blockxd keys add Wallet_Name
      OR
blockxd keys add Wallet_Name --recover
```

**Check all keys**

```python
blockxd keys list
```

**Check Balance**

```python
blockxd query bank balances blockx...addressjkl1yjgn7z09ua9vms259j
```

**Delete Key**

```python
blockxd keys delete Wallet_Name
```

**Export Key**

```python
blockxd keys export wallet
```

**Import Key**

```python
blockxd keys import wallet wallet.backup
```

## 🚀Validator Management

**Edit Validator**

```python
blockxd tx staking edit-validator \
--new-moniker "Your_Moniker" \
--identity "Keybase_ID" \
--details "Your_Description" \
--website "Your_Website" \
--security-contact "Your_Email" \
--chain-id blockx_190-1 \
--commission-rate 0.05 \
--from Wallet_Name \
--gas 350000 -y
```

**Your Valoper-Address**

```python
blockxd keys show Wallet_Name --bech val
```

**Your Valcons-Address**

```python
blockxd tendermint show-address
```

**Your Validator-Info**

```python
blockxd query staking validator blockxvaloperaddress......
```

**Jail Info**

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

**Unjail**

```python
blockxd tx slashing unjail --from Wallet_name --chain-id blockx_190-1 --gas 350000 -y
```

**Active Validators List**

```python
blockxd 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
```

**Inactive Validators List**

```python
blockxd 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
```

**Check that your key matches the validator (Win -&#x20;**<mark style="color:green;">**Good**</mark>**. Lose -** [<mark style="color:red;">**Bad**</mark>](#user-content-fn-1)[^1]**)**

```python
VALOPER=Enter_Your_valoper_Here
[[ $(blockxd q staking validator $VALOPER -oj | jq -r .consensus_pubkey.key) = $(blockxd status | jq -r .ValidatorInfo.PubKey.value) ]] && echo -e "\nYou win\n" || echo -e "\nYou lose\n"
```

**Withdraw all rewards from all validators**

```python
blockxd tx distribution withdraw-all-rewards --from Wallet_Name --chain-id blockx_190-1 --gas 350000 -y
```

**Withdraw and commission from your Validator**

```python
blockxd tx distribution withdraw-rewards blockxvaloper1amxp0k0hg4edrxg85v07t9ka2tfuhamhldgf8e --from Wallet_Name --gas 350000 --chain-id=blockx_190-1 --commission -y
```

**Delegate tokens to your validator**

```python
blockxd tx staking delegate Your_valpoer........ "100000000"abcx --from Wallet_Name --gas 350000 --chain-id=blockx_190-1 -y
```

**Delegate tokens to different validator**

```python
blockxd tx staking delegate valpoer........ "100000000"abcx --from Wallet_Name --gas 350000 --chain-id=blockx_190-1 -y
```

**Redelegate tokens to another validator**

```python
blockxd tx staking redelegate Your_valpoer........ valpoer........ "100000000"abcx --from Wallet_Name --gas 350000  --chain-id=blockx_190-1 -y
```

**Unbond tokens from your validator or different validator**

```python
blockxd tx staking unbond Your_valpoer........ "100000000"abcx --from Wallet_Name --gas 350000 --chain-id=blockx_190-1 -y
blockxd tx staking unbond valpoer........ "100000000"abcx --from Wallet_Name --gas 350000 --chain-id=blockx_190-1 -y
```

**Transfer tokens from wallet to wallet**

```python
blockxd tx bank send Your_address............ address........... "1000000000000000000"abcx --gas 350000 --chain-id=blockx_190-1 -y
```

## 📝Governance

**View all proposals**

```python
blockxd query gov proposals
```

**View specific proposal**

```python
blockxd query gov proposal 1
```

**Vote yes**

```python
blockxd tx gov vote 1 yes --from Wallet_Name --gas 350000  --chain-id=blockx_190-1 -y
```

**Vote no**

```python
blockxd tx gov vote 1 no --from Wallet_Name --gas 350000  --chain-id=blockx_190-1 -y
```

**Vote abstain**

```python
blockxd tx gov vote 1 abstain --from Wallet_Name --gas 350000  --chain-id=blockx_190-1 -y
```

**Vote no\_with\_veto**

```python
blockxd tx gov vote 1 no_with_veto --from Wallet_Name --gas 350000  --chain-id=blockx_190-1 -y
```

## 📡IBC transfer

* for exapmle - Blockx-> Osmosis

```python
blockxd tx ibc-transfer transfer transfer channel-2 Your_OSMOaddress............ "100000"abcx --from Your_Blockx_Wallet_Name ---gas 350000 --fees "7000"abcx --chain-id=blockx_190-1 -y
```

[^1]:


---

# 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://stavr-team.gitbook.io/nodes-guides/mainnets/blockx/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.
