mirror of
https://github.com/monero-project/monero-docs.git
synced 2025-01-08 20:09:31 +00:00
29 lines
No EOL
2.6 KiB
Markdown
29 lines
No EOL
2.6 KiB
Markdown
---
|
|
layout: default
|
|
title: Key Manipulation
|
|
parent: Cryptography In Monero
|
|
---
|
|
|
|
# Key Manipulation
|
|
|
|
Monero uses four keys for managing a wallet: private view key, public view key, private spend key, public spend key. View keys are used for viewing receive transactions and constructing public addresses meanwhile spend keys are used for viewing receive/send transactions and constructing transactions.
|
|
|
|
## Generating A Wallet And Deriving Keys Of It
|
|
|
|
Monero wallets are generated by selecting 24 cryptographically secure random words from [the wordlists (each has exactly 1626 words)](https://github.com/monero-project/monero/tree/master/src/mnemonics) and appending an extra checksum word calculated from the previous 24 words. The checksum word is selected by calculating the [CRC32 checksum index](https://en.wikipedia.org/wiki/Cyclic_redundancy_check) of a string that is made by concatenating the first `prefix_length`ed characters of each selected word.
|
|
|
|
For example, lets assume that our 24 random words are: \
|
|
`lush bagpipe stacking mice imitate village gang efficient strained different together vain puck roped pancakes shocking liar moisture memoir sorry syndrome kettle swept dehydrate`
|
|
|
|
As [English wordlist's](https://github.com/monero-project/monero/blob/master/src/mnemonics/english.h#L52C47-L52C48) prefix length is 3, we are concatenating only the first 3 letters of each word which get us this: \
|
|
`lusbagstamicimivilganeffstrdiftogvaipucroppansholiamoimemsorsynketswedeh`
|
|
|
|
And calculating the [CRC32 Checksum](https://en.wikipedia.org/wiki/Cyclic_redundancy_check) of this gives us the decimal number `2248614488`. Then we can take the modulo of it to choose the checksum word in our mnemonic. `2248614488 % 24` gives us 8 and 8th index of our mnemonic (don't forget that indexes start at 0) is `strained` so we choose this word as a checksum word. Which then gives us the final mnemonic that we can store: `lush bagpipe stacking mice imitate village gang efficient strained different together vain puck roped pancakes shocking liar moisture memoir sorry syndrome kettle swept dehydrate strained`
|
|
|
|
So to summarize, the steps are like this:
|
|
|
|
- Choose 24 random words from the wordlist [securely](https://en.wikipedia.org/wiki/Cryptographically_secure_pseudorandom_number_generator)
|
|
- Concatenate every first `prefix_length` characters of each word into a single string (For example, `prefix_length` is 3 for English and 4 for German)
|
|
- Calculate [CRC32 Checksum](https://en.wikipedia.org/wiki/Cyclic_redundancy_check) of the concatenated string
|
|
- Take 24th modulo of the CRC32 output
|
|
- Choose the word based on the modulo output |