Bitcoin Core 28.99.0
P2P Digital Currency
Public Member Functions | Public Attributes | List of all members
wallet::CMasterKey Class Reference

Private key encryption is done based on a CMasterKey, which holds a salt and random encryption key. More...

#include <crypter.h>

Public Member Functions

 SERIALIZE_METHODS (CMasterKey, obj)
 
 CMasterKey ()
 

Public Attributes

std::vector< unsigned char > vchCryptedKey
 
std::vector< unsigned char > vchSalt
 
unsigned int nDerivationMethod
 0 = EVP_sha512() 1 = scrypt() More...
 
unsigned int nDeriveIterations
 
std::vector< unsigned char > vchOtherDerivationParameters
 Use this for more parameters to key derivation, such as the various parameters to scrypt. More...
 

Detailed Description

Private key encryption is done based on a CMasterKey, which holds a salt and random encryption key.

CMasterKeys are encrypted using AES-256-CBC using a key derived using derivation method nDerivationMethod (0 == EVP_sha512()) and derivation iterations nDeriveIterations. vchOtherDerivationParameters is provided for alternative algorithms which may require more parameters (such as scrypt).

Wallet Private Keys are then encrypted using AES-256-CBC with the double-sha256 of the public key as the IV, and the master key's key as the encryption key (see keystore.[ch]). Master key for wallet encryption

Definition at line 34 of file crypter.h.

Constructor & Destructor Documentation

◆ CMasterKey()

wallet::CMasterKey::CMasterKey ( )
inline

Definition at line 52 of file crypter.h.

Member Function Documentation

◆ SERIALIZE_METHODS()

wallet::CMasterKey::SERIALIZE_METHODS ( CMasterKey  ,
obj   
)
inline

Definition at line 47 of file crypter.h.

Member Data Documentation

◆ nDerivationMethod

unsigned int wallet::CMasterKey::nDerivationMethod

0 = EVP_sha512() 1 = scrypt()

Definition at line 41 of file crypter.h.

◆ nDeriveIterations

unsigned int wallet::CMasterKey::nDeriveIterations

Definition at line 42 of file crypter.h.

◆ vchCryptedKey

std::vector<unsigned char> wallet::CMasterKey::vchCryptedKey

Definition at line 37 of file crypter.h.

◆ vchOtherDerivationParameters

std::vector<unsigned char> wallet::CMasterKey::vchOtherDerivationParameters

Use this for more parameters to key derivation, such as the various parameters to scrypt.

Definition at line 45 of file crypter.h.

◆ vchSalt

std::vector<unsigned char> wallet::CMasterKey::vchSalt

Definition at line 38 of file crypter.h.


The documentation for this class was generated from the following file: