forked from cosmos/cosmos-sdk
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge PR cosmos#4286: Add full ledger tutorial
* docs/cosmos-hub/ledger.md Add full ledger tutorial * Update ledger.md
- Loading branch information
1 parent
3bf1ec5
commit 3439101
Showing
3 changed files
with
220 additions
and
53 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
# HD Wallets | ||
|
||
Accounts in Cosmos are Hierarichial Deterministic (HD) Wallets. Originally specified in Bitcoin's [BIP32](https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki), HD wallets are a special kind of wallet that let users derive any number of accounts from a single seed. To understand what that means, let us first define some terminology: | ||
|
||
- **Wallet**: Set of accounts obtained from a given seed. | ||
- **Account**: A pair of public key/private key. | ||
- **Private Key**: A private key is a secret piece of information used to sign messages. In the blockchain context, a private key identifies the owner of an account. The private key of a user should never be revealed to others. | ||
- **Public Key**: A public key is a piece of information obtained by applying a one-way mathematical function on a private key. From it, an address can be derived. A private key cannot be found from a public key. | ||
- **Address**: An address is a public string with a human-readable prefix that identifies an account. It is obtained by applying mathematical transformations to a public key. | ||
- **Digital Signature**: A digital signature is a piece of cryptographic information that proves the owner of a given private key approved of a given message without revealing the private key. | ||
- **Seed**: Same as Mnemonic. | ||
- **Mnemonic**: A mnemonic is a sequence of words that is used as seed to derive private keys. The mnemonic is at the core of each wallet. NEVER LOSE YOUR MNEMONIC. WRITE IT DOWN ON A PIECE OF PAPER AND STORE IT SOMEWHERE SAFE. IF YOU LOSE IT, THERE IS NO WAY TO RETRIEVE IT. IF SOMEONE GAINS ACCESS TO IT, THEY GAIN ACCESS TO ALL THE ASSOCIATED ACCOUNTS. | ||
|
||
At the core of a HD wallet, there is a seed. From this seed, users can deterministically generate accounts. To generate an account from a seed, one-way mathematical transformations are applied. To decide which account to generate, the user specifies a `path`, generally an `integer` (`0`, `1`, `2`, ...). | ||
|
||
By specifying `path` to be `0` for example, the Wallet will generate `Private Key 0` from the seed. Then, `Public Key 0` can be generated from `Private Key 0`. Finally, `Address 0` can be generated from `Public Key 0`. All these steps are one way only, meaning the `Public Key` cannot be found from the `Address`, the `Private Key` cannot be found from the `Public Key`, ... | ||
|
||
``` | ||
Account 0 Account 1 Account 2 | ||
+------------------+ +------------------+ +------------------+ | ||
| | | | | | | ||
| Address 0 | | Address 1 | | Address 2 | | ||
| ^ | | ^ | | ^ | | ||
| | | | | | | | | | ||
| | | | | | | | | | ||
| | | | | | | | | | ||
| + | | + | | + | | ||
| Public key 0 | | Public key 1 | | Public key 2 | | ||
| ^ | | ^ | | ^ | | ||
| | | | | | | | | | ||
| | | | | | | | | | ||
| | | | | | | | | | ||
| + | | + | | + | | ||
| Private key 0 | | Private key 1 | | Private key 2 | | ||
| ^ | | ^ | | ^ | | ||
+------------------+ +------------------+ +------------------+ | ||
| | | | ||
| | | | ||
| | | | ||
+--------------------------------------------------------------------+ | ||
| | ||
| | ||
+---------+---------+ | ||
| | | ||
| Mnemonic (Seed) | | ||
| | | ||
+-------------------+ | ||
``` | ||
|
||
The process of derivating accounts from the seed is deterministic. This means that given the same path, the derived private key will always be the same. | ||
|
||
The funds stored in an account are controlled by the private key. This private key is generated using a one-way function from the mnemonic. If you lose the private key, you can retrieve it using the mnemonic. However, if you lose the mnemonic, you will lose access to all the derived private keys. Likewise, if someone gains access to your mnemonic, they gain access to all the associated accounts. | ||
|
||
::: danger | ||
**Do not lose or share your 24 words with anyone. To prevent theft or loss of funds, it is best to keep multiple copies of your mnemonic stored in safe, secure places. If someone is able to gain access to your mnemonic, they will fully control the accounts associated with them.** | ||
::: |
Oops, something went wrong.