Account
Last updated
Last updated
Settlus incorporates EVMOS account features, making it compatible with both Cosmos-based and Ethereum accounts. Users who create an Ethereum account on popular wallets (e.g., MetaMask) can immediately use their account on Settlus.
Aside from having different security features, the biggest difference between each of these is that a private key or keystore file only creates one account. Creating a mnemonic phrase gives you control of many accounts, all accessible with that same phrase.
Cosmos blockchains, like Settlus, support creating accounts with mnemonic phrases, otherwise known as (HD keys). This allows the user to create accounts on multiple blockchains without having to manage multiple secrets.
HD keys generate addresses by taking the mnemonic phrase and combining it with a piece of information called a . Blockchains can differ in which derivation path they support. To access all accounts from an mnemonic phrase on a blockchain, it is therefore important to use that blockchain's specific derivation path.
Settlus account implements .
defines a new format for segregated witness output addresses that contains a human-readable part that identifies the Bech32 usage. Settlus uses the following HRP (human readable prefix) as the base HRP:
There are 3 main types of HRP for the Addresses
/PubKeys
available by default on Settlus:
Addresses and Keys for accounts, which identify users (e.g. the sender of a message
). They are derived using the eth_secp256k1
curve.
Addresses and Keys for validator operators, which identify the operators of validators. They are derived using the eth_secp256k1
curve.
Addresses and Keys for consensus nodes, which identify the validator nodes participating in consensus. They are derived using the secp256k1
curve.
The Bech32 format is the default format for Cosmos-SDK queries and transactions through CLI and REST clients. The hex format on the other hand, is the Ethereum common.Address
representation of a Cosmos sdk.AccAddress
.
Address (Bech32): settlus1z3t55m0l9h0eupuz3dp5t5cypyv674jj7mz2jw
Compressed Public Key: {"@type":"/ethermint.crypto.v1.ethsecp256k1.PubKey","key":"AsV5oddeB+hkByIJo/4lZiVUgXTzNfBPKC73cZ4K1YD2"}
The settlusd debug addr <address>
can be used to convert an address between hex and bech32 formats. For example:
Bech32
Hex
TIP
The Cosmos SDK Keyring output (i.e settlusd keys
) only supports addresses and public keys in Bech32 format.
We can use the keys show
command of settlusd
with the flag --bech <type>(acc | val | cons)
to obtain the addresses and keys as mentioned above. Let's see some examples.
Accounts
Validator
Consensus
You can query an account address using the CLI, gRPC or REST API endpoint
EthAccount
can be represented in both (settlus1...
) and hex (0x...
) formats for Ethereum's Web3 tooling compatibility.
Address ( Hex): 0x91defC7fE5603DFA8CC9B655cF5772459BF10c6f
To retrieve the Ethereum hex address using Web3, use the JSON-RPC or endpoints:
Settlus
settlus
settlus
Accounts
settlus
settluspub
eth_secp256k1
20
33
(compressed)
Validator Operator
settlusvaloper
settlusvaloperpub
eth_secp256k1
20
33
(compressed)
Consensus Nodes
settlusvalcons
settlusvalconspub
secp256k1
20
32