Bitcoin Core  23.99.0
P2P Digital Currency
message.h
Go to the documentation of this file.
1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2020 The Bitcoin Core developers
3 // Distributed under the MIT software license, see the accompanying
4 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 
6 #ifndef BITCOIN_UTIL_MESSAGE_H
7 #define BITCOIN_UTIL_MESSAGE_H
8 
9 #include <uint256.h>
10 
11 #include <string>
12 
13 class CKey;
14 
15 extern const std::string MESSAGE_MAGIC;
16 
26 
29 
32 
35 
38 
40  OK
41 };
42 
43 enum class SigningResult {
44  OK,
47 };
48 
55  const std::string& address,
56  const std::string& signature,
57  const std::string& message);
58 
64 bool MessageSign(
65  const CKey& privkey,
66  const std::string& message,
67  std::string& signature);
68 
73 uint256 MessageHash(const std::string& message);
74 
75 std::string SigningResultString(const SigningResult res);
76 
77 #endif // BITCOIN_UTIL_MESSAGE_H
MessageVerificationResult::ERR_MALFORMED_SIGNATURE
@ ERR_MALFORMED_SIGNATURE
The provided signature couldn't be parsed (maybe invalid base64).
SigningResult::OK
@ OK
No error.
uint256.h
MessageVerificationResult::ERR_NOT_SIGNED
@ ERR_NOT_SIGNED
The message was not signed with the private key of the provided address.
SigningResult
SigningResult
Definition: message.h:43
MessageVerificationResult
MessageVerificationResult
The result of a signed message verification.
Definition: message.h:23
SigningResult::PRIVATE_KEY_NOT_AVAILABLE
@ PRIVATE_KEY_NOT_AVAILABLE
MessageSign
bool MessageSign(const CKey &privkey, const std::string &message, std::string &signature)
Sign a message.
Definition: message.cpp:59
MessageVerificationResult::ERR_INVALID_ADDRESS
@ ERR_INVALID_ADDRESS
The provided address is invalid.
uint256
256-bit opaque blob.
Definition: uint256.h:126
SigningResultString
std::string SigningResultString(const SigningResult res)
Definition: message.cpp:83
MessageVerificationResult::ERR_PUBKEY_NOT_RECOVERED
@ ERR_PUBKEY_NOT_RECOVERED
A public key could not be recovered from the provided signature and message.
MessageVerificationResult::ERR_ADDRESS_NO_KEY
@ ERR_ADDRESS_NO_KEY
The provided address is valid but does not refer to a public key.
MessageVerify
MessageVerificationResult MessageVerify(const std::string &address, const std::string &signature, const std::string &message)
Verify a signed message.
Definition: message.cpp:28
CKey
An encapsulated private key.
Definition: key.h:26
MessageHash
uint256 MessageHash(const std::string &message)
Hashes a message for signing and verification in a manner that prevents inadvertently signing a trans...
Definition: message.cpp:75
SigningResult::SIGNING_FAILED
@ SIGNING_FAILED
MessageVerificationResult::OK
@ OK
The message verification was successful.
MESSAGE_MAGIC
const std::string MESSAGE_MAGIC
Text used to signify that a signed message follows and to prevent inadvertently signing a transaction...
Definition: message.cpp:26