meta | canonicalUrl | |||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
cronosd
is an all-in-one command-line interface. It supports wallet management, funds transfers and staking operations.
- You can get the latest
cronosd
binary here from the release page;
cronosd
is bundled with the Crypto.org Chain code. After you have obtained the latest cronosd
binary, run
$ cronosd [command]
There is also a -h, --help
command available
$ cronosd -h
By default, your configuration and data are stored in the folder located in the ~/.cronos
directory.
Ensure that you have backed up your wallet after creating it. Otherwise, your funds may be inaccessible in the event of an accident.
To specify the cronosd config and data storage directory; you can add a global flag --home <directory>
We can view the default config setting by using cronosd config
command:
$ cronosd config
{
"chain-id": "",
"keyring-backend": "os",
"output": "text",
"node": "tcp://localhost:26657",
"broadcast-mode": "sync"
}
We can make changes to the default settings upon our choices, so it allows users to set the configuration beforehand all at once, so it would be ready with the same config afterward.
For example, the chain-id
can be changed to cronostestnet_338-1
from a blank name by
$ cronosd config "chain-id" cronostestnet_338-1
$ cronosd config
{
"chain-id": "cronostestnet_338-1",
"keyring-backend": "os",
"output": "text",
"node": "tcp://localhost:26657",
"broadcast-mode": "sync"
}
Other values can be changed in the same way.
Alternatively, we can directly make the changes to the config values in one place at client.toml. It is under the path of .ethermint/config/client.toml
in the folder where we installed ethermint:
############################################################################
### Client Configuration ###
############################################################################
# The network chain ID
chain-id = "cronostestnet_338-1"
# The keyring's backend, where the keys are stored (os|file|kwallet|pass|test|memory)
keyring-backend = "os"
# CLI output format (text|json)
output = "number"
# <host>:<port> to Tendermint RPC interface for this chain
node = "tcp://localhost:26657"
# Transaction broadcasting mode (sync|async|block)
broadcast-mode = "sync"
After the necessary changes are made in the client.toml
, then save. For example, if we directly change the chain-id
from ethermint0
to ethermint-test1, and output to number, it would change instantly as shown below.
$ cronosd config
{
"chain-id": "ethermint-test1",
"keyring-backend": "os",
"output": "number",
"node": "tcp://localhost:26657",
"broadcast-mode": "sync"
}
A list of commonly used flags of cronosd is listed below:
Option | Description | Type | Default Value |
---|---|---|---|
--home |
Directory for config and data | string | ~/.cronos |
--chain-id |
Full Chain ID | String | --- |
--output |
Output format | string | "text" |
--keyring-backend |
Select keyring's backend | os/file/test | os |
A list of commonly used cronosd
commands.
You may also add the flag -h, --help
on cronosd [command]
to get more available commands and details.
{% hint style="info" %} Example: More details of subcommand - tx staking
$ cronosd tx staking --help
Staking transaction subcommands
Usage:
cronosd tx staking [flags]
cronosd tx staking [command]
Available Commands:
create-validator create new validator initialized with a self-delegation to it
delegate Delegate liquid tokens to a validator
edit-validator edit an existing validator account
redelegate Redelegate illiquid tokens from one validator to another
unbond Unbond shares from a validator
Flags:
-h, --help help for staking
Global Flags:
--chain-id string The network chain ID
--home string directory for config and data (default "/Users/.cronos")
--log_format string The logging format (json|plain) (default "plain")
--log_level string The logging level (trace|debug|info|warn|error|fatal|panic) (default "info")
--trace
{% endhint %}
First of all, you will need an address to store and spend your CRO.
You can create a new key with the name Default
as in the following example:
{% hint style="info" %} Example: Create a new address
$ cronosd keys add Default
- name: Default
type: local
address: tcrc1r4erhyx6jk8nsafhlw7263upnw9hja90gdgj5d
pubkey: '{"@type":"/ethermint.crypto.v1alpha1.ethsecp256k1.PubKey","key":"A3EzNez+oPwDnRTY9OWdVDSjOqikiP7zYncTyxil2SgO"}'
mnemonic: ""
**Important** write this mnemonic phrase in a safe place.
It is the only way to recover your account if you ever forget your password.
farm surround surround hunt shop glory fringe bag mountain clerk arch ankle announce turtle slide brisk carbon album immense drop example speed grain dutch
{% endhint %}
The key comes with a "mnemonic phrase", which is serialized into a human-readable 24-word mnemonic. User can recover their associated addresses with the mnemonic phrase.
{% hint style="danger" %} It is important that you keep the mnemonic for address secure, as there is no way to recover it. You would not be able to recover and access the funds in the wallet if you forget the mnemonic phrase. {% endhint %}
You can restore an existing key with the mnemonic.
{% hint style="info" %} Example: Restore an existing key
$ cronosd keys add Default_restore --recover
> Enter your bip39 mnemonic
## Enter your 24-word mnemonic here ##
{% endhint %}
Multiple keys can be created when needed. You can list all keys saved under the storage path.
{% hint style="info" %} Example: List all of your keys
$ cronosd keys list
- name: Default
type: local
address: ## Address of "Default" ##
pubkey: ## Pubkey of "Default" ##
mnemonic: ""
threshold: 0
pubkeys: []
- name: Default_restore
type: local
address: ## Address of "Default_restore" ##
pubkey: ## Pubkey of "Default_restore" ##
mnemonic: ""
threshold: 0
pubkeys: []
{% endhint %}
You can retrieve key information by its name:
{% hint style="info" %} Example: Retrieve key information - Account Address and its public key
$ cronosd keys show mykey --bech acc
- name: mykey
type: local
address: tcrc1qsklxwt77qrxur494uvw07zjynu03dq9alwh37
pubkey: '{"@type":"/ethermint.crypto.v1alpha1.ethsecp256k1.PubKey","key":"A8nbJ3eW9oAb2RNZoS8L71jFMfjk6zVa1UISYgKK9HPm"}'
mnemonic: ""
{% endhint %}
{% hint style="info" %} Example: Retrieve key information - Validator Address and its public key
$ cronosd keys show Default --bech val
$ cronosd keys show test --bech val
- name: mykey
type: local
address: ethvaloper1qsklxwt77qrxur494uvw07zjynu03dq9rdsrlq
pubkey: '{"@type":"/ethermint.crypto.v1alpha1.ethsecp256k1.PubKey","key":"A8nbJ3eW9oAb2RNZoS8L71jFMfjk6zVa1UISYgKK9HPm"}'
mnemonic: ""
{% endhint %}
{% hint style="info" %} Example: Retrieve key information - Consensus nodes Address and its public key
$ cronosd keys show Default --bech cons
$ cronosd keys show test --bech cons
- name: mykey
type: local
address: ethvalcons1qsklxwt77qrxur494uvw07zjynu03dq9h7rlnp
pubkey: '{"@type":"/ethermint.crypto.v1alpha1.ethsecp256k1.PubKey","key":"A8nbJ3eW9oAb2RNZoS8L71jFMfjk6zVa1UISYgKK9HPm"}'
mnemonic: ""
{% endhint %}
You can delete a key in your storage path.
{% hint style="danger" %} Make sure you have backed up the key mnemonic before removing any of your keys, as there will be no way to recover your key without the mnemonic. {% endhint %}
{% hint style="info" %} Example: Remove a key
$ cronosd keys delete Default_restore1
Key reference will be deleted. Continue? [y/N]: y
Key deleted forever (uh oh!)
{% endhint %}
You can export and backup your key by using the export
subcommand:
{% hint style="info" %} Example: Export your keys Exporting the key Default :
$ cronosd keys export Default
Enter passphrase to encrypt the exported key: ## Insert passphrase (must be at least 8 characters)##
-----BEGIN TENDERMINT PRIVATE KEY-----
kdf: bcrypt
salt: ## Salt of the key ##
type: secp256k1
## Tendermint private key ##
-----END TENDERMINT PRIVATE KEY-----
{% endhint %}
Interacting with a node requires a public-private key pair. Keyring is the place holding the keys. The keys can be stored in different locations with specified backend type.
$ cronosd keys [subcommands] --keyring-backend [backend type]
The default os
backend stores the keys in operating system's credential sub-system, which are comfortable to most users, yet without compromising on security.
Here is a list of the corresponding password managers in different operating systems:
- macOS (since Mac OS 8.6): Keychain
- Windows: Credentials Management API
- GNU/Linux:
The file
backend stores the encrypted keys inside the app's configuration directory. A password entry is required every time a user access it, which may also occur multiple times of repeated password prompts in one single command.
The test
backend is a password-less variation of the file
backend. It stores unencrypted keys inside the app's configuration directory. It should only be used in testing environments and never be used in production.
Transfer operation involves the transfer of tokens between two addresses.
{% hint style="info" %} Example: Send 10tcro from one address to another.
$ cronosd tx bank send Default tcrc1gjdxrv77zfpq6cywcs8kg6gqyfhl5768ucel6t 10tcro --chain-id cronostestnet_338-1
## Transaction payload##
{"body":{"messages":[{"@type":"/cosmos.bank.v1beta1.MsgSend","from_address"....}
confirm transaction before signing and broadcasting [y/N]: y
{% endhint %}
Staking operations involve the interaction between an address and a validator. It allows you to create a validator and lock/unlocking funds for staking purposes.
To bond funds for staking, you can delegate funds to a validator by the delegate
command
{% hint style="info" %}
Example: Delegate funds from mykey
to a validator under the address ethvaloper...lq
$ cronosd tx staking delegate ethvaloper1qsklxwt77qrxur494uvw07zjynu03dq9rdsrlq 100tcro --from mykey --chain-id cronostestnet_338-1
## Transactions payload##
{"body":{"messages":[{"@type":"/cosmos.staking.v1beta1.MsgDelegate"....}
confirm transaction before signing and broadcasting [y/N]: y
{% endhint %}
On the other hand, we can create a Unbond
transaction to unbond the delegated funds
{% hint style="info" %}
Example: Unbond funds from a validator under the address ethvaloper...lq
$ cronosd tx staking unbond ethvaloper1qsklxwt77qrxur494uvw07zjynu03dq9rdsrlq 100tcro --from mykey --chain-id cronostestnet_338-1
## Transaction payload##
{"body":{"messages":[{"@type":"/cosmos.staking.v1beta1.MsgUndelegate"...}
confirm transaction before signing and broadcasting [y/N]: y
{% endhint %}
{% hint style="info" %}
Once your funds are unbonded, it will be locked until theunbonding_time
has passed.
{% endhint %}
You can check your transferable balance with the balances
command under the bank module.
{% hint style="info" %} Example: Check your address balance
$ cronosd query bank balances tcrc1a303tt49l5uhe87yaneyggly83g7e4uncdxqtl --output json | jq
{
"balances": [
{
"denom": "basetcro",
"amount": "99999000000000000000000000"
}
],
"pagination": {
"next_key": null,
"total": "0"
}
}
{% endhint %}
To recover from an app-hash mismatch failure, it would take hours to re-run an archive node,
a faster way to do it as of cronos v1.0.2 would be to use rollback
.
cronosd rollback
//rollback example at current height 6569206
Rolled back state to height 6569205 and hash 5BFA3A9FA0C207B83D327330ADE77C46A5E688A24864614843C743FDFD968BCD%
{% hint style="danger" %} Only use this command if you are solely using evm-level queries as evm JSON-RPC queries will remain available after re-indexing, however cosmos-level tx will not be available anymore. For example, this will no longer be possible: https://rpc.cronos.org/tx_search?query=_&prove=_&page=_&per_page=_&order_by=_ {% endhint %}
After v1.0.2
nodes can now enable the custom transaction indexer to reduce disk size.
The custom tx indexer can be enabled in app.toml
by setting the json-rpc.enable-indexer
to true
. Usually, you will want to re-index previous indexed blocks by using the --backward
field, e.g.:
cronosd index-eth-tx backward
After running the re-index command you will notice in your .cronos/data/
directory a new file called evmindexer.db
from which you can see that the size is smaller than the original tx_index.db
. You can now safely remove the tx_index.db
file.
Anyone who wishes to become a validator can submit a create-validator
transaction by
$ cronosd tx staking create-validator [flags]
{% hint style="info" %} Example: Joining the network as a validator
$ cronosd tx staking create-validator \
--amount="100cro" \
--pubkey='{"@type":...,"key":...}' \
--moniker="The_new_node" \
--chain-id="cronostestnet_338-1" \
--commission-rate="0.10" \
--commission-max-rate="0.20" \
--commission-max-change-rate="0.01" \
--min-self-delegation="1" \
--from=node1
## Transactions payload##
{"body":{"messages":[{"@type":"/cosmos.staking.v1beta1.MsgCreateValidator"...}
confirm transaction before signing and broadcasting [y/N]: y
{% endhint %}
(TODO: details of each flag )
Validator could be punished and jailed due to network misbehaviour, for example, if we check the validator set:
$ cronosd query staking validators -o json | jq
................................
"operator_address": "ethvaloper1zwm45n5r3u3xcpsd00d3arwzhz7250rtsadv65",
"consensus_pubkey": {
"@type": "/cosmos.crypto.ed25519.PubKey",
"key": "fD6cWVYv5rsNbXDw3hVIbB3nd9x57HsTyeMgwmH472U="
},
"jailed": false,
"status": "BOND_STATUS_BONDED",
................................
After the jailing period has passed, one can broadcast a unjail
transaction to unjail the validator and resume its normal operations by
$ cronosd tx slashing unjail --from node1 --chain-id cronostestnet_338-1
{"body":{"messages":[{"@type":"/cosmos.slashing.v1beta1.MsgUnjail"...}]}
confirm transaction before signing and broadcasting [y/N]: y