Bitcoin
|
#include <key.h>
Public Member Functions | |
CKey () | |
Construct an invalid private key. More... | |
template<typename T > | |
void | Set (const T pbegin, const T pend, bool fCompressedIn) |
Initialize using begin and end iterators to byte data. More... | |
unsigned int | size () const |
Simple read-only vector-like interface. More... | |
const unsigned char * | begin () const |
const unsigned char * | end () const |
bool | IsValid () const |
Check whether this private key is valid. More... | |
bool | IsCompressed () const |
Check whether the public key corresponding to this private key is (to be) compressed. More... | |
void | MakeNewKey (bool fCompressed) |
Generate a new private key using a cryptographic PRNG. More... | |
bool | Negate () |
Negate private key. More... | |
CPrivKey | GetPrivKey () const |
CPubKey | GetPubKey () const |
bool | Sign (const uint256 &hash, std::vector< unsigned char > &vchSig, bool grind=true, uint32_t test_case=0) const |
bool | SignCompact (const uint256 &hash, std::vector< unsigned char > &vchSig) const |
bool | Derive (CKey &keyChild, ChainCode &ccChild, unsigned int nChild, const ChainCode &cc) const |
Derive BIP32 child key. More... | |
bool | VerifyPubKey (const CPubKey &vchPubKey) const |
bool | Load (const CPrivKey &privkey, const CPubKey &vchPubKey, bool fSkipCheck) |
Load private key and check that public key matches. More... | |
Static Public Attributes | |
static const unsigned int | PRIVATE_KEY_SIZE = 279 |
static const unsigned int | COMPRESSED_PRIVATE_KEY_SIZE = 214 |
Static Private Member Functions | |
static bool | Check (const unsigned char *vch) |
Check whether the 32-byte array pointed to by vch is valid keydata. More... | |
Private Attributes | |
bool | fValid |
bool | fCompressed |
Whether the public key corresponding to this private key is (to be) compressed. More... | |
std::vector< unsigned char, secure_allocator< unsigned char > > | keydata |
The actual byte data. More... | |
Friends | |
bool | operator== (const CKey &a, const CKey &b) |
An encapsulated private key.
|
inline |
Construct an invalid private key.
|
inline |
|
staticprivate |
Check whether the 32-byte array pointed to by vch is valid keydata.
bool CKey::Derive | ( | CKey & | keyChild, |
ChainCode & | ccChild, | ||
unsigned int | nChild, | ||
const ChainCode & | cc | ||
) | const |
Derive BIP32 child key.
|
inline |
CPrivKey CKey::GetPrivKey | ( | ) | const |
Convert the private key to a CPrivKey (serialized OpenSSL private key data). This is expensive.
CPubKey CKey::GetPubKey | ( | ) | const |
Compute the public key from a private key. This is expensive.
|
inline |
Check whether the public key corresponding to this private key is (to be) compressed.
|
inline |
Check whether this private key is valid.
Load private key and check that public key matches.
void CKey::MakeNewKey | ( | bool | fCompressed | ) |
Generate a new private key using a cryptographic PRNG.
bool CKey::Negate | ( | ) |
Negate private key.
|
inline |
Initialize using begin and end iterators to byte data.
bool CKey::Sign | ( | const uint256 & | hash, |
std::vector< unsigned char > & | vchSig, | ||
bool | grind = true , |
||
uint32_t | test_case = 0 |
||
) | const |
Create a DER-serialized signature. The test_case parameter tweaks the deterministic nonce.
bool CKey::SignCompact | ( | const uint256 & | hash, |
std::vector< unsigned char > & | vchSig | ||
) | const |
Create a compact signature (65 bytes), which allows reconstructing the used public key. The format is one header byte, followed by two times 32 bytes for the serialized r and s values. The header byte: 0x1B = first key with even y, 0x1C = first key with odd y, 0x1D = second key with even y, 0x1E = second key with odd y, add 0x04 for compressed keys.
|
inline |
Simple read-only vector-like interface.
bool CKey::VerifyPubKey | ( | const CPubKey & | vchPubKey | ) | const |
Verify thoroughly whether a private key and a public key match. This is done using a different mechanism than just regenerating it.
|
static |
|
private |
Whether the public key corresponding to this private key is (to be) compressed.
|
private |
see www.keylength.com script supports up to 75 for single byte pushWhether this private key is valid. We check for correctness when modifying the key data, so fValid should always correspond to the actual state.
|
private |
The actual byte data.
|
static |
secp256k1: