Bitcoin Core 28.99.0
P2P Digital Currency
addresstype.cpp
Go to the documentation of this file.
1// Copyright (c) 2023 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or https://www.opensource.org/licenses/mit-license.php.
4
5#include <addresstype.h>
6
7#include <crypto/sha256.h>
8#include <hash.h>
9#include <pubkey.h>
10#include <script/script.h>
11#include <script/solver.h>
12#include <uint256.h>
13#include <util/hash_type.h>
14
15#include <cassert>
16#include <vector>
17
18typedef std::vector<unsigned char> valtype;
19
22
23PKHash::PKHash(const CPubKey& pubkey) : BaseHash(pubkey.GetID()) {}
24PKHash::PKHash(const CKeyID& pubkey_id) : BaseHash(pubkey_id) {}
25
26WitnessV0KeyHash::WitnessV0KeyHash(const CPubKey& pubkey) : BaseHash(pubkey.GetID()) {}
27WitnessV0KeyHash::WitnessV0KeyHash(const PKHash& pubkey_hash) : BaseHash{pubkey_hash} {}
28
29CKeyID ToKeyID(const PKHash& key_hash)
30{
31 return CKeyID{uint160{key_hash}};
32}
33
35{
36 return CKeyID{uint160{key_hash}};
37}
38
39CScriptID ToScriptID(const ScriptHash& script_hash)
40{
41 return CScriptID{uint160{script_hash}};
42}
43
45{
46 CSHA256().Write(in.data(), in.size()).Finalize(begin());
47}
48
49bool ExtractDestination(const CScript& scriptPubKey, CTxDestination& addressRet)
50{
51 std::vector<valtype> vSolutions;
52 TxoutType whichType = Solver(scriptPubKey, vSolutions);
53
54 switch (whichType) {
55 case TxoutType::PUBKEY: {
56 CPubKey pubKey(vSolutions[0]);
57 if (!pubKey.IsValid()) {
58 addressRet = CNoDestination(scriptPubKey);
59 } else {
60 addressRet = PubKeyDestination(pubKey);
61 }
62 return false;
63 }
65 addressRet = PKHash(uint160(vSolutions[0]));
66 return true;
67 }
69 addressRet = ScriptHash(uint160(vSolutions[0]));
70 return true;
71 }
74 std::copy(vSolutions[0].begin(), vSolutions[0].end(), hash.begin());
75 addressRet = hash;
76 return true;
77 }
80 std::copy(vSolutions[0].begin(), vSolutions[0].end(), hash.begin());
81 addressRet = hash;
82 return true;
83 }
86 std::copy(vSolutions[0].begin(), vSolutions[0].end(), tap.begin());
87 addressRet = tap;
88 return true;
89 }
90 case TxoutType::ANCHOR: {
91 addressRet = PayToAnchor();
92 return true;
93 }
95 addressRet = WitnessUnknown{vSolutions[0][0], vSolutions[1]};
96 return true;
97 }
101 addressRet = CNoDestination(scriptPubKey);
102 return false;
103 } // no default case, so the compiler can warn about missing cases
104 assert(false);
105}
106
107namespace {
108class CScriptVisitor
109{
110public:
111 CScript operator()(const CNoDestination& dest) const
112 {
113 return dest.GetScript();
114 }
115
116 CScript operator()(const PubKeyDestination& dest) const
117 {
118 return CScript() << ToByteVector(dest.GetPubKey()) << OP_CHECKSIG;
119 }
120
121 CScript operator()(const PKHash& keyID) const
122 {
123 return CScript() << OP_DUP << OP_HASH160 << ToByteVector(keyID) << OP_EQUALVERIFY << OP_CHECKSIG;
124 }
125
126 CScript operator()(const ScriptHash& scriptID) const
127 {
128 return CScript() << OP_HASH160 << ToByteVector(scriptID) << OP_EQUAL;
129 }
130
131 CScript operator()(const WitnessV0KeyHash& id) const
132 {
133 return CScript() << OP_0 << ToByteVector(id);
134 }
135
136 CScript operator()(const WitnessV0ScriptHash& id) const
137 {
138 return CScript() << OP_0 << ToByteVector(id);
139 }
140
141 CScript operator()(const WitnessV1Taproot& tap) const
142 {
143 return CScript() << OP_1 << ToByteVector(tap);
144 }
145
146 CScript operator()(const WitnessUnknown& id) const
147 {
148 return CScript() << CScript::EncodeOP_N(id.GetWitnessVersion()) << id.GetWitnessProgram();
149 }
150};
151
152class ValidDestinationVisitor
153{
154public:
155 bool operator()(const CNoDestination& dest) const { return false; }
156 bool operator()(const PubKeyDestination& dest) const { return false; }
157 bool operator()(const PKHash& dest) const { return true; }
158 bool operator()(const ScriptHash& dest) const { return true; }
159 bool operator()(const WitnessV0KeyHash& dest) const { return true; }
160 bool operator()(const WitnessV0ScriptHash& dest) const { return true; }
161 bool operator()(const WitnessV1Taproot& dest) const { return true; }
162 bool operator()(const WitnessUnknown& dest) const { return true; }
163};
164} // namespace
165
167{
168 return std::visit(CScriptVisitor(), dest);
169}
170
172 return std::visit(ValidDestinationVisitor(), dest);
173}
CScriptID ToScriptID(const ScriptHash &script_hash)
Definition: addresstype.cpp:39
std::vector< unsigned char > valtype
Definition: addresstype.cpp:18
bool ExtractDestination(const CScript &scriptPubKey, CTxDestination &addressRet)
Parse a scriptPubKey for the destination.
Definition: addresstype.cpp:49
bool IsValidDestination(const CTxDestination &dest)
Check whether a CTxDestination corresponds to one with an address.
CScript GetScriptForDestination(const CTxDestination &dest)
Generate a Bitcoin scriptPubKey for the given CTxDestination.
CKeyID ToKeyID(const PKHash &key_hash)
Definition: addresstype.cpp:29
std::variant< CNoDestination, PubKeyDestination, PKHash, ScriptHash, WitnessV0ScriptHash, WitnessV0KeyHash, WitnessV1Taproot, PayToAnchor, WitnessUnknown > CTxDestination
A txout script categorized into standard templates.
Definition: addresstype.h:140
unsigned char * begin()
Definition: hash_type.h:18
A reference to a CKey: the Hash160 of its serialized public key.
Definition: pubkey.h:24
const CScript & GetScript() const LIFETIMEBOUND
Definition: addresstype.h:28
An encapsulated public key.
Definition: pubkey.h:34
bool IsValid() const
Definition: pubkey.h:189
A hasher class for SHA-256.
Definition: sha256.h:14
void Finalize(unsigned char hash[OUTPUT_SIZE])
Definition: sha256.cpp:727
CSHA256 & Write(const unsigned char *data, size_t len)
Definition: sha256.cpp:701
Serialized script, used inside transaction inputs and outputs.
Definition: script.h:415
static opcodetype EncodeOP_N(int n)
Definition: script.h:524
A reference to a CScript: the Hash160 of its serialization.
Definition: script.h:602
const unsigned char * begin() const
Definition: pubkey.h:295
size_type size() const
Definition: prevector.h:294
value_type * data()
Definition: prevector.h:533
160-bit opaque blob.
Definition: uint256.h:189
uint160 Hash160(const T1 &in1)
Compute the 160-bit hash an object.
Definition: hash.h:92
@ OP_CHECKSIG
Definition: script.h:190
@ OP_EQUAL
Definition: script.h:146
@ OP_DUP
Definition: script.h:125
@ OP_HASH160
Definition: script.h:187
@ OP_1
Definition: script.h:83
@ OP_0
Definition: script.h:76
@ OP_EQUALVERIFY
Definition: script.h:147
std::vector< unsigned char > ToByteVector(const T &in)
Definition: script.h:67
TxoutType Solver(const CScript &scriptPubKey, std::vector< std::vector< unsigned char > > &vSolutionsRet)
Parse a scriptPubKey and identify script type for standard scripts.
Definition: solver.cpp:141
TxoutType
Definition: solver.h:22
@ WITNESS_V1_TAPROOT
@ WITNESS_UNKNOWN
Only for Witness versions not already defined above.
@ ANCHOR
anyone can spend script
@ WITNESS_V0_SCRIPTHASH
@ NULL_DATA
unspendable OP_RETURN script that carries data
@ WITNESS_V0_KEYHASH
PKHash()
Definition: addresstype.h:49
const CPubKey & GetPubKey() const LIFETIMEBOUND
Definition: addresstype.h:41
CTxDestination subtype to encode any future Witness version.
Definition: addresstype.h:96
assert(!tx.IsCoinBase())