Bitcoin Core 28.99.0
P2P Digital Currency
psbt.h
Go to the documentation of this file.
1// Copyright (c) 2009-2022 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#ifndef BITCOIN_PSBT_H
6#define BITCOIN_PSBT_H
7
8#include <node/transaction.h>
9#include <policy/feerate.h>
11#include <pubkey.h>
12#include <script/keyorigin.h>
13#include <script/sign.h>
15#include <span.h>
16#include <streams.h>
17
18#include <optional>
19
20namespace node {
21enum class TransactionError;
22} // namespace node
23
24// Magic bytes
25static constexpr uint8_t PSBT_MAGIC_BYTES[5] = {'p', 's', 'b', 't', 0xff};
26
27// Global types
28static constexpr uint8_t PSBT_GLOBAL_UNSIGNED_TX = 0x00;
29static constexpr uint8_t PSBT_GLOBAL_XPUB = 0x01;
30static constexpr uint8_t PSBT_GLOBAL_VERSION = 0xFB;
31static constexpr uint8_t PSBT_GLOBAL_PROPRIETARY = 0xFC;
32
33// Input types
34static constexpr uint8_t PSBT_IN_NON_WITNESS_UTXO = 0x00;
35static constexpr uint8_t PSBT_IN_WITNESS_UTXO = 0x01;
36static constexpr uint8_t PSBT_IN_PARTIAL_SIG = 0x02;
37static constexpr uint8_t PSBT_IN_SIGHASH = 0x03;
38static constexpr uint8_t PSBT_IN_REDEEMSCRIPT = 0x04;
39static constexpr uint8_t PSBT_IN_WITNESSSCRIPT = 0x05;
40static constexpr uint8_t PSBT_IN_BIP32_DERIVATION = 0x06;
41static constexpr uint8_t PSBT_IN_SCRIPTSIG = 0x07;
42static constexpr uint8_t PSBT_IN_SCRIPTWITNESS = 0x08;
43static constexpr uint8_t PSBT_IN_RIPEMD160 = 0x0A;
44static constexpr uint8_t PSBT_IN_SHA256 = 0x0B;
45static constexpr uint8_t PSBT_IN_HASH160 = 0x0C;
46static constexpr uint8_t PSBT_IN_HASH256 = 0x0D;
47static constexpr uint8_t PSBT_IN_TAP_KEY_SIG = 0x13;
48static constexpr uint8_t PSBT_IN_TAP_SCRIPT_SIG = 0x14;
49static constexpr uint8_t PSBT_IN_TAP_LEAF_SCRIPT = 0x15;
50static constexpr uint8_t PSBT_IN_TAP_BIP32_DERIVATION = 0x16;
51static constexpr uint8_t PSBT_IN_TAP_INTERNAL_KEY = 0x17;
52static constexpr uint8_t PSBT_IN_TAP_MERKLE_ROOT = 0x18;
53static constexpr uint8_t PSBT_IN_PROPRIETARY = 0xFC;
54
55// Output types
56static constexpr uint8_t PSBT_OUT_REDEEMSCRIPT = 0x00;
57static constexpr uint8_t PSBT_OUT_WITNESSSCRIPT = 0x01;
58static constexpr uint8_t PSBT_OUT_BIP32_DERIVATION = 0x02;
59static constexpr uint8_t PSBT_OUT_TAP_INTERNAL_KEY = 0x05;
60static constexpr uint8_t PSBT_OUT_TAP_TREE = 0x06;
61static constexpr uint8_t PSBT_OUT_TAP_BIP32_DERIVATION = 0x07;
62static constexpr uint8_t PSBT_OUT_PROPRIETARY = 0xFC;
63
64// The separator is 0x00. Reading this in means that the unserializer can interpret it
65// as a 0 length key which indicates that this is the separator. The separator has no value.
66static constexpr uint8_t PSBT_SEPARATOR = 0x00;
67
68// BIP 174 does not specify a maximum file size, but we set a limit anyway
69// to prevent reading a stream indefinitely and running out of memory.
70const std::streamsize MAX_FILE_SIZE_PSBT = 100000000; // 100 MB
71
72// PSBT version number
73static constexpr uint32_t PSBT_HIGHEST_VERSION = 0;
74
77{
78 uint64_t subtype;
79 std::vector<unsigned char> identifier;
80 std::vector<unsigned char> key;
81 std::vector<unsigned char> value;
82
83 bool operator<(const PSBTProprietary &b) const {
84 return key < b.key;
85 }
86 bool operator==(const PSBTProprietary &b) const {
87 return key == b.key;
88 }
89};
90
91// Takes a stream and multiple arguments and serializes them as if first serialized into a vector and then into the stream
92// The resulting output into the stream has the total serialized length of all of the objects followed by all objects concatenated with each other.
93template<typename Stream, typename... X>
94void SerializeToVector(Stream& s, const X&... args)
95{
96 SizeComputer sizecomp;
97 SerializeMany(sizecomp, args...);
98 WriteCompactSize(s, sizecomp.size());
99 SerializeMany(s, args...);
100}
101
102// Takes a stream and multiple arguments and unserializes them first as a vector then each object individually in the order provided in the arguments
103template<typename Stream, typename... X>
104void UnserializeFromVector(Stream& s, X&&... args)
105{
106 size_t expected_size = ReadCompactSize(s);
107 size_t remaining_before = s.size();
109 size_t remaining_after = s.size();
110 if (remaining_after + expected_size != remaining_before) {
111 throw std::ios_base::failure("Size of value was not the stated size");
112 }
113}
114
115// Deserialize bytes of given length from the stream as a KeyOriginInfo
116template<typename Stream>
117KeyOriginInfo DeserializeKeyOrigin(Stream& s, uint64_t length)
118{
119 // Read in key path
120 if (length % 4 || length == 0) {
121 throw std::ios_base::failure("Invalid length for HD key path");
122 }
123
124 KeyOriginInfo hd_keypath;
125 s >> hd_keypath.fingerprint;
126 for (unsigned int i = 4; i < length; i += sizeof(uint32_t)) {
127 uint32_t index;
128 s >> index;
129 hd_keypath.path.push_back(index);
130 }
131 return hd_keypath;
132}
133
134// Deserialize a length prefixed KeyOriginInfo from a stream
135template<typename Stream>
136void DeserializeHDKeypath(Stream& s, KeyOriginInfo& hd_keypath)
137{
138 hd_keypath = DeserializeKeyOrigin(s, ReadCompactSize(s));
139}
140
141// Deserialize HD keypaths into a map
142template<typename Stream>
143void DeserializeHDKeypaths(Stream& s, const std::vector<unsigned char>& key, std::map<CPubKey, KeyOriginInfo>& hd_keypaths)
144{
145 // Make sure that the key is the size of pubkey + 1
146 if (key.size() != CPubKey::SIZE + 1 && key.size() != CPubKey::COMPRESSED_SIZE + 1) {
147 throw std::ios_base::failure("Size of key was not the expected size for the type BIP32 keypath");
148 }
149 // Read in the pubkey from key
150 CPubKey pubkey(key.begin() + 1, key.end());
151 if (!pubkey.IsFullyValid()) {
152 throw std::ios_base::failure("Invalid pubkey");
153 }
154 if (hd_keypaths.count(pubkey) > 0) {
155 throw std::ios_base::failure("Duplicate Key, pubkey derivation path already provided");
156 }
157
158 KeyOriginInfo keypath;
159 DeserializeHDKeypath(s, keypath);
160
161 // Add to map
162 hd_keypaths.emplace(pubkey, std::move(keypath));
163}
164
165// Serialize a KeyOriginInfo to a stream
166template<typename Stream>
167void SerializeKeyOrigin(Stream& s, KeyOriginInfo hd_keypath)
168{
169 s << hd_keypath.fingerprint;
170 for (const auto& path : hd_keypath.path) {
171 s << path;
172 }
173}
174
175// Serialize a length prefixed KeyOriginInfo to a stream
176template<typename Stream>
177void SerializeHDKeypath(Stream& s, KeyOriginInfo hd_keypath)
178{
179 WriteCompactSize(s, (hd_keypath.path.size() + 1) * sizeof(uint32_t));
180 SerializeKeyOrigin(s, hd_keypath);
181}
182
183// Serialize HD keypaths to a stream from a map
184template<typename Stream>
185void SerializeHDKeypaths(Stream& s, const std::map<CPubKey, KeyOriginInfo>& hd_keypaths, CompactSizeWriter type)
186{
187 for (const auto& keypath_pair : hd_keypaths) {
188 if (!keypath_pair.first.IsValid()) {
189 throw std::ios_base::failure("Invalid CPubKey being serialized");
190 }
191 SerializeToVector(s, type, Span{keypath_pair.first});
192 SerializeHDKeypath(s, keypath_pair.second);
193 }
194}
195
198{
205 std::map<CPubKey, KeyOriginInfo> hd_keypaths;
206 std::map<CKeyID, SigPair> partial_sigs;
207 std::map<uint160, std::vector<unsigned char>> ripemd160_preimages;
208 std::map<uint256, std::vector<unsigned char>> sha256_preimages;
209 std::map<uint160, std::vector<unsigned char>> hash160_preimages;
210 std::map<uint256, std::vector<unsigned char>> hash256_preimages;
211
212 // Taproot fields
213 std::vector<unsigned char> m_tap_key_sig;
214 std::map<std::pair<XOnlyPubKey, uint256>, std::vector<unsigned char>> m_tap_script_sigs;
215 std::map<std::pair<std::vector<unsigned char>, int>, std::set<std::vector<unsigned char>, ShortestVectorFirstComparator>> m_tap_scripts;
216 std::map<XOnlyPubKey, std::pair<std::set<uint256>, KeyOriginInfo>> m_tap_bip32_paths;
219
220 std::map<std::vector<unsigned char>, std::vector<unsigned char>> unknown;
221 std::set<PSBTProprietary> m_proprietary;
222 std::optional<int> sighash_type;
223
224 bool IsNull() const;
225 void FillSignatureData(SignatureData& sigdata) const;
226 void FromSignatureData(const SignatureData& sigdata);
227 void Merge(const PSBTInput& input);
228 PSBTInput() = default;
229
230 template <typename Stream>
231 inline void Serialize(Stream& s) const {
232 // Write the utxo
233 if (non_witness_utxo) {
236 }
237 if (!witness_utxo.IsNull()) {
240 }
241
243 // Write any partial signatures
244 for (const auto& sig_pair : partial_sigs) {
246 s << sig_pair.second.second;
247 }
248
249 // Write the sighash type
250 if (sighash_type != std::nullopt) {
253 }
254
255 // Write the redeem script
256 if (!redeem_script.empty()) {
258 s << redeem_script;
259 }
260
261 // Write the witness script
262 if (!witness_script.empty()) {
264 s << witness_script;
265 }
266
267 // Write any hd keypaths
269
270 // Write any ripemd160 preimage
271 for (const auto& [hash, preimage] : ripemd160_preimages) {
273 s << preimage;
274 }
275
276 // Write any sha256 preimage
277 for (const auto& [hash, preimage] : sha256_preimages) {
279 s << preimage;
280 }
281
282 // Write any hash160 preimage
283 for (const auto& [hash, preimage] : hash160_preimages) {
285 s << preimage;
286 }
287
288 // Write any hash256 preimage
289 for (const auto& [hash, preimage] : hash256_preimages) {
291 s << preimage;
292 }
293
294 // Write taproot key sig
295 if (!m_tap_key_sig.empty()) {
297 s << m_tap_key_sig;
298 }
299
300 // Write taproot script sigs
301 for (const auto& [pubkey_leaf, sig] : m_tap_script_sigs) {
302 const auto& [xonly, leaf_hash] = pubkey_leaf;
303 SerializeToVector(s, PSBT_IN_TAP_SCRIPT_SIG, xonly, leaf_hash);
304 s << sig;
305 }
306
307 // Write taproot leaf scripts
308 for (const auto& [leaf, control_blocks] : m_tap_scripts) {
309 const auto& [script, leaf_ver] = leaf;
310 for (const auto& control_block : control_blocks) {
312 std::vector<unsigned char> value_v(script.begin(), script.end());
313 value_v.push_back((uint8_t)leaf_ver);
314 s << value_v;
315 }
316 }
317
318 // Write taproot bip32 keypaths
319 for (const auto& [xonly, leaf_origin] : m_tap_bip32_paths) {
320 const auto& [leaf_hashes, origin] = leaf_origin;
322 std::vector<unsigned char> value;
323 VectorWriter s_value{value, 0};
324 s_value << leaf_hashes;
325 SerializeKeyOrigin(s_value, origin);
326 s << value;
327 }
328
329 // Write taproot internal key
330 if (!m_tap_internal_key.IsNull()) {
333 }
334
335 // Write taproot merkle root
336 if (!m_tap_merkle_root.IsNull()) {
339 }
340 }
341
342 // Write script sig
343 if (!final_script_sig.empty()) {
346 }
347 // write script witness
351 }
352
353 // Write proprietary things
354 for (const auto& entry : m_proprietary) {
355 s << entry.key;
356 s << entry.value;
357 }
358
359 // Write unknown things
360 for (auto& entry : unknown) {
361 s << entry.first;
362 s << entry.second;
363 }
364
365 s << PSBT_SEPARATOR;
366 }
367
368
369 template <typename Stream>
370 inline void Unserialize(Stream& s) {
371 // Used for duplicate key detection
372 std::set<std::vector<unsigned char>> key_lookup;
373
374 // Read loop
375 bool found_sep = false;
376 while(!s.empty()) {
377 // Read
378 std::vector<unsigned char> key;
379 s >> key;
380
381 // the key is empty if that was actually a separator byte
382 // This is a special case for key lengths 0 as those are not allowed (except for separator)
383 if (key.empty()) {
384 found_sep = true;
385 break;
386 }
387
388 // Type is compact size uint at beginning of key
389 SpanReader skey{key};
390 uint64_t type = ReadCompactSize(skey);
391
392 // Do stuff based on type
393 switch(type) {
395 {
396 if (!key_lookup.emplace(key).second) {
397 throw std::ios_base::failure("Duplicate Key, input non-witness utxo already provided");
398 } else if (key.size() != 1) {
399 throw std::ios_base::failure("Non-witness utxo key is more than one byte type");
400 }
401 // Set the stream to unserialize with witness since this is always a valid network transaction
403 break;
404 }
406 if (!key_lookup.emplace(key).second) {
407 throw std::ios_base::failure("Duplicate Key, input witness utxo already provided");
408 } else if (key.size() != 1) {
409 throw std::ios_base::failure("Witness utxo key is more than one byte type");
410 }
412 break;
414 {
415 // Make sure that the key is the size of pubkey + 1
416 if (key.size() != CPubKey::SIZE + 1 && key.size() != CPubKey::COMPRESSED_SIZE + 1) {
417 throw std::ios_base::failure("Size of key was not the expected size for the type partial signature pubkey");
418 }
419 // Read in the pubkey from key
420 CPubKey pubkey(key.begin() + 1, key.end());
421 if (!pubkey.IsFullyValid()) {
422 throw std::ios_base::failure("Invalid pubkey");
423 }
424 if (partial_sigs.count(pubkey.GetID()) > 0) {
425 throw std::ios_base::failure("Duplicate Key, input partial signature for pubkey already provided");
426 }
427
428 // Read in the signature from value
429 std::vector<unsigned char> sig;
430 s >> sig;
431
432 // Add to list
433 partial_sigs.emplace(pubkey.GetID(), SigPair(pubkey, std::move(sig)));
434 break;
435 }
436 case PSBT_IN_SIGHASH:
437 if (!key_lookup.emplace(key).second) {
438 throw std::ios_base::failure("Duplicate Key, input sighash type already provided");
439 } else if (key.size() != 1) {
440 throw std::ios_base::failure("Sighash type key is more than one byte type");
441 }
442 int sighash;
443 UnserializeFromVector(s, sighash);
444 sighash_type = sighash;
445 break;
447 {
448 if (!key_lookup.emplace(key).second) {
449 throw std::ios_base::failure("Duplicate Key, input redeemScript already provided");
450 } else if (key.size() != 1) {
451 throw std::ios_base::failure("Input redeemScript key is more than one byte type");
452 }
453 s >> redeem_script;
454 break;
455 }
457 {
458 if (!key_lookup.emplace(key).second) {
459 throw std::ios_base::failure("Duplicate Key, input witnessScript already provided");
460 } else if (key.size() != 1) {
461 throw std::ios_base::failure("Input witnessScript key is more than one byte type");
462 }
463 s >> witness_script;
464 break;
465 }
467 {
469 break;
470 }
472 {
473 if (!key_lookup.emplace(key).second) {
474 throw std::ios_base::failure("Duplicate Key, input final scriptSig already provided");
475 } else if (key.size() != 1) {
476 throw std::ios_base::failure("Final scriptSig key is more than one byte type");
477 }
479 break;
480 }
482 {
483 if (!key_lookup.emplace(key).second) {
484 throw std::ios_base::failure("Duplicate Key, input final scriptWitness already provided");
485 } else if (key.size() != 1) {
486 throw std::ios_base::failure("Final scriptWitness key is more than one byte type");
487 }
489 break;
490 }
492 {
493 // Make sure that the key is the size of a ripemd160 hash + 1
494 if (key.size() != CRIPEMD160::OUTPUT_SIZE + 1) {
495 throw std::ios_base::failure("Size of key was not the expected size for the type ripemd160 preimage");
496 }
497 // Read in the hash from key
498 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
499 uint160 hash(hash_vec);
500 if (ripemd160_preimages.count(hash) > 0) {
501 throw std::ios_base::failure("Duplicate Key, input ripemd160 preimage already provided");
502 }
503
504 // Read in the preimage from value
505 std::vector<unsigned char> preimage;
506 s >> preimage;
507
508 // Add to preimages list
509 ripemd160_preimages.emplace(hash, std::move(preimage));
510 break;
511 }
512 case PSBT_IN_SHA256:
513 {
514 // Make sure that the key is the size of a sha256 hash + 1
515 if (key.size() != CSHA256::OUTPUT_SIZE + 1) {
516 throw std::ios_base::failure("Size of key was not the expected size for the type sha256 preimage");
517 }
518 // Read in the hash from key
519 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
520 uint256 hash(hash_vec);
521 if (sha256_preimages.count(hash) > 0) {
522 throw std::ios_base::failure("Duplicate Key, input sha256 preimage already provided");
523 }
524
525 // Read in the preimage from value
526 std::vector<unsigned char> preimage;
527 s >> preimage;
528
529 // Add to preimages list
530 sha256_preimages.emplace(hash, std::move(preimage));
531 break;
532 }
533 case PSBT_IN_HASH160:
534 {
535 // Make sure that the key is the size of a hash160 hash + 1
536 if (key.size() != CHash160::OUTPUT_SIZE + 1) {
537 throw std::ios_base::failure("Size of key was not the expected size for the type hash160 preimage");
538 }
539 // Read in the hash from key
540 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
541 uint160 hash(hash_vec);
542 if (hash160_preimages.count(hash) > 0) {
543 throw std::ios_base::failure("Duplicate Key, input hash160 preimage already provided");
544 }
545
546 // Read in the preimage from value
547 std::vector<unsigned char> preimage;
548 s >> preimage;
549
550 // Add to preimages list
551 hash160_preimages.emplace(hash, std::move(preimage));
552 break;
553 }
554 case PSBT_IN_HASH256:
555 {
556 // Make sure that the key is the size of a hash256 hash + 1
557 if (key.size() != CHash256::OUTPUT_SIZE + 1) {
558 throw std::ios_base::failure("Size of key was not the expected size for the type hash256 preimage");
559 }
560 // Read in the hash from key
561 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
562 uint256 hash(hash_vec);
563 if (hash256_preimages.count(hash) > 0) {
564 throw std::ios_base::failure("Duplicate Key, input hash256 preimage already provided");
565 }
566
567 // Read in the preimage from value
568 std::vector<unsigned char> preimage;
569 s >> preimage;
570
571 // Add to preimages list
572 hash256_preimages.emplace(hash, std::move(preimage));
573 break;
574 }
576 {
577 if (!key_lookup.emplace(key).second) {
578 throw std::ios_base::failure("Duplicate Key, input Taproot key signature already provided");
579 } else if (key.size() != 1) {
580 throw std::ios_base::failure("Input Taproot key signature key is more than one byte type");
581 }
582 s >> m_tap_key_sig;
583 if (m_tap_key_sig.size() < 64) {
584 throw std::ios_base::failure("Input Taproot key path signature is shorter than 64 bytes");
585 } else if (m_tap_key_sig.size() > 65) {
586 throw std::ios_base::failure("Input Taproot key path signature is longer than 65 bytes");
587 }
588 break;
589 }
591 {
592 if (!key_lookup.emplace(key).second) {
593 throw std::ios_base::failure("Duplicate Key, input Taproot script signature already provided");
594 } else if (key.size() != 65) {
595 throw std::ios_base::failure("Input Taproot script signature key is not 65 bytes");
596 }
597 SpanReader s_key{Span{key}.subspan(1)};
598 XOnlyPubKey xonly;
599 uint256 hash;
600 s_key >> xonly;
601 s_key >> hash;
602 std::vector<unsigned char> sig;
603 s >> sig;
604 if (sig.size() < 64) {
605 throw std::ios_base::failure("Input Taproot script path signature is shorter than 64 bytes");
606 } else if (sig.size() > 65) {
607 throw std::ios_base::failure("Input Taproot script path signature is longer than 65 bytes");
608 }
609 m_tap_script_sigs.emplace(std::make_pair(xonly, hash), sig);
610 break;
611 }
613 {
614 if (!key_lookup.emplace(key).second) {
615 throw std::ios_base::failure("Duplicate Key, input Taproot leaf script already provided");
616 } else if (key.size() < 34) {
617 throw std::ios_base::failure("Taproot leaf script key is not at least 34 bytes");
618 } else if ((key.size() - 2) % 32 != 0) {
619 throw std::ios_base::failure("Input Taproot leaf script key's control block size is not valid");
620 }
621 std::vector<unsigned char> script_v;
622 s >> script_v;
623 if (script_v.empty()) {
624 throw std::ios_base::failure("Input Taproot leaf script must be at least 1 byte");
625 }
626 uint8_t leaf_ver = script_v.back();
627 script_v.pop_back();
628 const auto leaf_script = std::make_pair(script_v, (int)leaf_ver);
629 m_tap_scripts[leaf_script].insert(std::vector<unsigned char>(key.begin() + 1, key.end()));
630 break;
631 }
633 {
634 if (!key_lookup.emplace(key).second) {
635 throw std::ios_base::failure("Duplicate Key, input Taproot BIP32 keypath already provided");
636 } else if (key.size() != 33) {
637 throw std::ios_base::failure("Input Taproot BIP32 keypath key is not at 33 bytes");
638 }
639 SpanReader s_key{Span{key}.subspan(1)};
640 XOnlyPubKey xonly;
641 s_key >> xonly;
642 std::set<uint256> leaf_hashes;
643 uint64_t value_len = ReadCompactSize(s);
644 size_t before_hashes = s.size();
645 s >> leaf_hashes;
646 size_t after_hashes = s.size();
647 size_t hashes_len = before_hashes - after_hashes;
648 if (hashes_len > value_len) {
649 throw std::ios_base::failure("Input Taproot BIP32 keypath has an invalid length");
650 }
651 size_t origin_len = value_len - hashes_len;
652 m_tap_bip32_paths.emplace(xonly, std::make_pair(leaf_hashes, DeserializeKeyOrigin(s, origin_len)));
653 break;
654 }
656 {
657 if (!key_lookup.emplace(key).second) {
658 throw std::ios_base::failure("Duplicate Key, input Taproot internal key already provided");
659 } else if (key.size() != 1) {
660 throw std::ios_base::failure("Input Taproot internal key key is more than one byte type");
661 }
663 break;
664 }
666 {
667 if (!key_lookup.emplace(key).second) {
668 throw std::ios_base::failure("Duplicate Key, input Taproot merkle root already provided");
669 } else if (key.size() != 1) {
670 throw std::ios_base::failure("Input Taproot merkle root key is more than one byte type");
671 }
673 break;
674 }
676 {
677 PSBTProprietary this_prop;
678 skey >> this_prop.identifier;
679 this_prop.subtype = ReadCompactSize(skey);
680 this_prop.key = key;
681
682 if (m_proprietary.count(this_prop) > 0) {
683 throw std::ios_base::failure("Duplicate Key, proprietary key already found");
684 }
685 s >> this_prop.value;
686 m_proprietary.insert(this_prop);
687 break;
688 }
689 // Unknown stuff
690 default:
691 if (unknown.count(key) > 0) {
692 throw std::ios_base::failure("Duplicate Key, key for unknown value already provided");
693 }
694 // Read in the value
695 std::vector<unsigned char> val_bytes;
696 s >> val_bytes;
697 unknown.emplace(std::move(key), std::move(val_bytes));
698 break;
699 }
700 }
701
702 if (!found_sep) {
703 throw std::ios_base::failure("Separator is missing at the end of an input map");
704 }
705 }
706
707 template <typename Stream>
709 Unserialize(s);
710 }
711};
712
715{
718 std::map<CPubKey, KeyOriginInfo> hd_keypaths;
720 std::vector<std::tuple<uint8_t, uint8_t, std::vector<unsigned char>>> m_tap_tree;
721 std::map<XOnlyPubKey, std::pair<std::set<uint256>, KeyOriginInfo>> m_tap_bip32_paths;
722 std::map<std::vector<unsigned char>, std::vector<unsigned char>> unknown;
723 std::set<PSBTProprietary> m_proprietary;
724
725 bool IsNull() const;
726 void FillSignatureData(SignatureData& sigdata) const;
727 void FromSignatureData(const SignatureData& sigdata);
728 void Merge(const PSBTOutput& output);
729 PSBTOutput() = default;
730
731 template <typename Stream>
732 inline void Serialize(Stream& s) const {
733 // Write the redeem script
734 if (!redeem_script.empty()) {
736 s << redeem_script;
737 }
738
739 // Write the witness script
740 if (!witness_script.empty()) {
742 s << witness_script;
743 }
744
745 // Write any hd keypaths
747
748 // Write proprietary things
749 for (const auto& entry : m_proprietary) {
750 s << entry.key;
751 s << entry.value;
752 }
753
754 // Write taproot internal key
755 if (!m_tap_internal_key.IsNull()) {
758 }
759
760 // Write taproot tree
761 if (!m_tap_tree.empty()) {
763 std::vector<unsigned char> value;
764 VectorWriter s_value{value, 0};
765 for (const auto& [depth, leaf_ver, script] : m_tap_tree) {
766 s_value << depth;
767 s_value << leaf_ver;
768 s_value << script;
769 }
770 s << value;
771 }
772
773 // Write taproot bip32 keypaths
774 for (const auto& [xonly, leaf] : m_tap_bip32_paths) {
775 const auto& [leaf_hashes, origin] = leaf;
777 std::vector<unsigned char> value;
778 VectorWriter s_value{value, 0};
779 s_value << leaf_hashes;
780 SerializeKeyOrigin(s_value, origin);
781 s << value;
782 }
783
784 // Write unknown things
785 for (auto& entry : unknown) {
786 s << entry.first;
787 s << entry.second;
788 }
789
790 s << PSBT_SEPARATOR;
791 }
792
793
794 template <typename Stream>
795 inline void Unserialize(Stream& s) {
796 // Used for duplicate key detection
797 std::set<std::vector<unsigned char>> key_lookup;
798
799 // Read loop
800 bool found_sep = false;
801 while(!s.empty()) {
802 // Read
803 std::vector<unsigned char> key;
804 s >> key;
805
806 // the key is empty if that was actually a separator byte
807 // This is a special case for key lengths 0 as those are not allowed (except for separator)
808 if (key.empty()) {
809 found_sep = true;
810 break;
811 }
812
813 // Type is compact size uint at beginning of key
814 SpanReader skey{key};
815 uint64_t type = ReadCompactSize(skey);
816
817 // Do stuff based on type
818 switch(type) {
820 {
821 if (!key_lookup.emplace(key).second) {
822 throw std::ios_base::failure("Duplicate Key, output redeemScript already provided");
823 } else if (key.size() != 1) {
824 throw std::ios_base::failure("Output redeemScript key is more than one byte type");
825 }
826 s >> redeem_script;
827 break;
828 }
830 {
831 if (!key_lookup.emplace(key).second) {
832 throw std::ios_base::failure("Duplicate Key, output witnessScript already provided");
833 } else if (key.size() != 1) {
834 throw std::ios_base::failure("Output witnessScript key is more than one byte type");
835 }
836 s >> witness_script;
837 break;
838 }
840 {
842 break;
843 }
845 {
846 if (!key_lookup.emplace(key).second) {
847 throw std::ios_base::failure("Duplicate Key, output Taproot internal key already provided");
848 } else if (key.size() != 1) {
849 throw std::ios_base::failure("Output Taproot internal key key is more than one byte type");
850 }
852 break;
853 }
855 {
856 if (!key_lookup.emplace(key).second) {
857 throw std::ios_base::failure("Duplicate Key, output Taproot tree already provided");
858 } else if (key.size() != 1) {
859 throw std::ios_base::failure("Output Taproot tree key is more than one byte type");
860 }
861 std::vector<unsigned char> tree_v;
862 s >> tree_v;
863 SpanReader s_tree{tree_v};
864 if (s_tree.empty()) {
865 throw std::ios_base::failure("Output Taproot tree must not be empty");
866 }
867 TaprootBuilder builder;
868 while (!s_tree.empty()) {
869 uint8_t depth;
870 uint8_t leaf_ver;
871 std::vector<unsigned char> script;
872 s_tree >> depth;
873 s_tree >> leaf_ver;
874 s_tree >> script;
875 if (depth > TAPROOT_CONTROL_MAX_NODE_COUNT) {
876 throw std::ios_base::failure("Output Taproot tree has as leaf greater than Taproot maximum depth");
877 }
878 if ((leaf_ver & ~TAPROOT_LEAF_MASK) != 0) {
879 throw std::ios_base::failure("Output Taproot tree has a leaf with an invalid leaf version");
880 }
881 m_tap_tree.emplace_back(depth, leaf_ver, script);
882 builder.Add((int)depth, script, (int)leaf_ver, /*track=*/true);
883 }
884 if (!builder.IsComplete()) {
885 throw std::ios_base::failure("Output Taproot tree is malformed");
886 }
887 break;
888 }
890 {
891 if (!key_lookup.emplace(key).second) {
892 throw std::ios_base::failure("Duplicate Key, output Taproot BIP32 keypath already provided");
893 } else if (key.size() != 33) {
894 throw std::ios_base::failure("Output Taproot BIP32 keypath key is not at 33 bytes");
895 }
896 XOnlyPubKey xonly(uint256(Span<uint8_t>(key).last(32)));
897 std::set<uint256> leaf_hashes;
898 uint64_t value_len = ReadCompactSize(s);
899 size_t before_hashes = s.size();
900 s >> leaf_hashes;
901 size_t after_hashes = s.size();
902 size_t hashes_len = before_hashes - after_hashes;
903 if (hashes_len > value_len) {
904 throw std::ios_base::failure("Output Taproot BIP32 keypath has an invalid length");
905 }
906 size_t origin_len = value_len - hashes_len;
907 m_tap_bip32_paths.emplace(xonly, std::make_pair(leaf_hashes, DeserializeKeyOrigin(s, origin_len)));
908 break;
909 }
911 {
912 PSBTProprietary this_prop;
913 skey >> this_prop.identifier;
914 this_prop.subtype = ReadCompactSize(skey);
915 this_prop.key = key;
916
917 if (m_proprietary.count(this_prop) > 0) {
918 throw std::ios_base::failure("Duplicate Key, proprietary key already found");
919 }
920 s >> this_prop.value;
921 m_proprietary.insert(this_prop);
922 break;
923 }
924 // Unknown stuff
925 default: {
926 if (unknown.count(key) > 0) {
927 throw std::ios_base::failure("Duplicate Key, key for unknown value already provided");
928 }
929 // Read in the value
930 std::vector<unsigned char> val_bytes;
931 s >> val_bytes;
932 unknown.emplace(std::move(key), std::move(val_bytes));
933 break;
934 }
935 }
936 }
937
938 if (!found_sep) {
939 throw std::ios_base::failure("Separator is missing at the end of an output map");
940 }
941 }
942
943 template <typename Stream>
945 Unserialize(s);
946 }
947};
948
951{
952 std::optional<CMutableTransaction> tx;
953 // We use a vector of CExtPubKey in the event that there happens to be the same KeyOriginInfos for different CExtPubKeys
954 // Note that this map swaps the key and values from the serialization
955 std::map<KeyOriginInfo, std::set<CExtPubKey>> m_xpubs;
956 std::vector<PSBTInput> inputs;
957 std::vector<PSBTOutput> outputs;
958 std::map<std::vector<unsigned char>, std::vector<unsigned char>> unknown;
959 std::optional<uint32_t> m_version;
960 std::set<PSBTProprietary> m_proprietary;
961
962 bool IsNull() const;
963 uint32_t GetVersion() const;
964
967 [[nodiscard]] bool Merge(const PartiallySignedTransaction& psbt);
968 bool AddInput(const CTxIn& txin, PSBTInput& psbtin);
969 bool AddOutput(const CTxOut& txout, const PSBTOutput& psbtout);
979 bool GetInputUTXO(CTxOut& utxo, int input_index) const;
980
981 template <typename Stream>
982 inline void Serialize(Stream& s) const {
983
984 // magic bytes
986
987 // unsigned tx flag
989
990 // Write serialized tx to a stream
992
993 // Write xpubs
994 for (const auto& xpub_pair : m_xpubs) {
995 for (const auto& xpub : xpub_pair.second) {
996 unsigned char ser_xpub[BIP32_EXTKEY_WITH_VERSION_SIZE];
997 xpub.EncodeWithVersion(ser_xpub);
998 // Note that the serialization swaps the key and value
999 // The xpub is the key (for uniqueness) while the path is the value
1001 SerializeHDKeypath(s, xpub_pair.first);
1002 }
1003 }
1004
1005 // PSBT version
1006 if (GetVersion() > 0) {
1009 }
1010
1011 // Write proprietary things
1012 for (const auto& entry : m_proprietary) {
1013 s << entry.key;
1014 s << entry.value;
1015 }
1016
1017 // Write the unknown things
1018 for (auto& entry : unknown) {
1019 s << entry.first;
1020 s << entry.second;
1021 }
1022
1023 // Separator
1024 s << PSBT_SEPARATOR;
1025
1026 // Write inputs
1027 for (const PSBTInput& input : inputs) {
1028 s << input;
1029 }
1030 // Write outputs
1031 for (const PSBTOutput& output : outputs) {
1032 s << output;
1033 }
1034 }
1035
1036
1037 template <typename Stream>
1038 inline void Unserialize(Stream& s) {
1039 // Read the magic bytes
1040 uint8_t magic[5];
1041 s >> magic;
1042 if (!std::equal(magic, magic + 5, PSBT_MAGIC_BYTES)) {
1043 throw std::ios_base::failure("Invalid PSBT magic bytes");
1044 }
1045
1046 // Used for duplicate key detection
1047 std::set<std::vector<unsigned char>> key_lookup;
1048
1049 // Track the global xpubs we have already seen. Just for sanity checking
1050 std::set<CExtPubKey> global_xpubs;
1051
1052 // Read global data
1053 bool found_sep = false;
1054 while(!s.empty()) {
1055 // Read
1056 std::vector<unsigned char> key;
1057 s >> key;
1058
1059 // the key is empty if that was actually a separator byte
1060 // This is a special case for key lengths 0 as those are not allowed (except for separator)
1061 if (key.empty()) {
1062 found_sep = true;
1063 break;
1064 }
1065
1066 // Type is compact size uint at beginning of key
1067 SpanReader skey{key};
1068 uint64_t type = ReadCompactSize(skey);
1069
1070 // Do stuff based on type
1071 switch(type) {
1073 {
1074 if (!key_lookup.emplace(key).second) {
1075 throw std::ios_base::failure("Duplicate Key, unsigned tx already provided");
1076 } else if (key.size() != 1) {
1077 throw std::ios_base::failure("Global unsigned tx key is more than one byte type");
1078 }
1080 // Set the stream to serialize with non-witness since this should always be non-witness
1082 tx = std::move(mtx);
1083 // Make sure that all scriptSigs and scriptWitnesses are empty
1084 for (const CTxIn& txin : tx->vin) {
1085 if (!txin.scriptSig.empty() || !txin.scriptWitness.IsNull()) {
1086 throw std::ios_base::failure("Unsigned tx does not have empty scriptSigs and scriptWitnesses.");
1087 }
1088 }
1089 break;
1090 }
1091 case PSBT_GLOBAL_XPUB:
1092 {
1093 if (key.size() != BIP32_EXTKEY_WITH_VERSION_SIZE + 1) {
1094 throw std::ios_base::failure("Size of key was not the expected size for the type global xpub");
1095 }
1096 // Read in the xpub from key
1097 CExtPubKey xpub;
1098 xpub.DecodeWithVersion(&key.data()[1]);
1099 if (!xpub.pubkey.IsFullyValid()) {
1100 throw std::ios_base::failure("Invalid pubkey");
1101 }
1102 if (global_xpubs.count(xpub) > 0) {
1103 throw std::ios_base::failure("Duplicate key, global xpub already provided");
1104 }
1105 global_xpubs.insert(xpub);
1106 // Read in the keypath from stream
1107 KeyOriginInfo keypath;
1108 DeserializeHDKeypath(s, keypath);
1109
1110 // Note that we store these swapped to make searches faster.
1111 // Serialization uses xpub -> keypath to enqure key uniqueness
1112 if (m_xpubs.count(keypath) == 0) {
1113 // Make a new set to put the xpub in
1114 m_xpubs[keypath] = {xpub};
1115 } else {
1116 // Insert xpub into existing set
1117 m_xpubs[keypath].insert(xpub);
1118 }
1119 break;
1120 }
1122 {
1123 if (m_version) {
1124 throw std::ios_base::failure("Duplicate Key, version already provided");
1125 } else if (key.size() != 1) {
1126 throw std::ios_base::failure("Global version key is more than one byte type");
1127 }
1128 uint32_t v;
1130 m_version = v;
1132 throw std::ios_base::failure("Unsupported version number");
1133 }
1134 break;
1135 }
1137 {
1138 PSBTProprietary this_prop;
1139 skey >> this_prop.identifier;
1140 this_prop.subtype = ReadCompactSize(skey);
1141 this_prop.key = key;
1142
1143 if (m_proprietary.count(this_prop) > 0) {
1144 throw std::ios_base::failure("Duplicate Key, proprietary key already found");
1145 }
1146 s >> this_prop.value;
1147 m_proprietary.insert(this_prop);
1148 break;
1149 }
1150 // Unknown stuff
1151 default: {
1152 if (unknown.count(key) > 0) {
1153 throw std::ios_base::failure("Duplicate Key, key for unknown value already provided");
1154 }
1155 // Read in the value
1156 std::vector<unsigned char> val_bytes;
1157 s >> val_bytes;
1158 unknown.emplace(std::move(key), std::move(val_bytes));
1159 }
1160 }
1161 }
1162
1163 if (!found_sep) {
1164 throw std::ios_base::failure("Separator is missing at the end of the global map");
1165 }
1166
1167 // Make sure that we got an unsigned tx
1168 if (!tx) {
1169 throw std::ios_base::failure("No unsigned transaction was provided");
1170 }
1171
1172 // Read input data
1173 unsigned int i = 0;
1174 while (!s.empty() && i < tx->vin.size()) {
1175 PSBTInput input;
1176 s >> input;
1177 inputs.push_back(input);
1178
1179 // Make sure the non-witness utxo matches the outpoint
1180 if (input.non_witness_utxo) {
1181 if (input.non_witness_utxo->GetHash() != tx->vin[i].prevout.hash) {
1182 throw std::ios_base::failure("Non-witness UTXO does not match outpoint hash");
1183 }
1184 if (tx->vin[i].prevout.n >= input.non_witness_utxo->vout.size()) {
1185 throw std::ios_base::failure("Input specifies output index that does not exist");
1186 }
1187 }
1188 ++i;
1189 }
1190 // Make sure that the number of inputs matches the number of inputs in the transaction
1191 if (inputs.size() != tx->vin.size()) {
1192 throw std::ios_base::failure("Inputs provided does not match the number of inputs in transaction.");
1193 }
1194
1195 // Read output data
1196 i = 0;
1197 while (!s.empty() && i < tx->vout.size()) {
1198 PSBTOutput output;
1199 s >> output;
1200 outputs.push_back(output);
1201 ++i;
1202 }
1203 // Make sure that the number of outputs matches the number of outputs in the transaction
1204 if (outputs.size() != tx->vout.size()) {
1205 throw std::ios_base::failure("Outputs provided does not match the number of outputs in transaction.");
1206 }
1207 }
1208
1209 template <typename Stream>
1211 Unserialize(s);
1212 }
1213};
1214
1215enum class PSBTRole {
1216 CREATOR,
1217 UPDATER,
1218 SIGNER,
1219 FINALIZER,
1220 EXTRACTOR
1221};
1222
1223std::string PSBTRoleName(PSBTRole role);
1224
1227
1229bool PSBTInputSigned(const PSBTInput& input);
1230
1232bool PSBTInputSignedAndVerified(const PartiallySignedTransaction psbt, unsigned int input_index, const PrecomputedTransactionData* txdata);
1233
1239bool SignPSBTInput(const SigningProvider& provider, PartiallySignedTransaction& psbt, int index, const PrecomputedTransactionData* txdata, int sighash = SIGHASH_ALL, SignatureData* out_sigdata = nullptr, bool finalize = true);
1240
1242void RemoveUnnecessaryTransactions(PartiallySignedTransaction& psbtx, const int& sighash_type);
1243
1246
1251void UpdatePSBTOutput(const SigningProvider& provider, PartiallySignedTransaction& psbt, int index);
1252
1260
1269
1277[[nodiscard]] bool CombinePSBTs(PartiallySignedTransaction& out, const std::vector<PartiallySignedTransaction>& psbtxs);
1278
1280[[nodiscard]] bool DecodeBase64PSBT(PartiallySignedTransaction& decoded_psbt, const std::string& base64_psbt, std::string& error);
1282[[nodiscard]] bool DecodeRawPSBT(PartiallySignedTransaction& decoded_psbt, Span<const std::byte> raw_psbt, std::string& error);
1283
1284#endif // BITCOIN_PSBT_H
ArgsManager & args
Definition: bitcoind.cpp:277
static const size_t OUTPUT_SIZE
Definition: hash.h:53
static const size_t OUTPUT_SIZE
Definition: hash.h:28
An encapsulated public key.
Definition: pubkey.h:34
CKeyID GetID() const
Get the KeyID of this public key (hash of its serialization)
Definition: pubkey.h:164
static constexpr unsigned int COMPRESSED_SIZE
Definition: pubkey.h:40
static constexpr unsigned int SIZE
secp256k1:
Definition: pubkey.h:39
bool IsFullyValid() const
fully validate whether this is a valid public key (more expensive than IsValid())
Definition: pubkey.cpp:314
static const size_t OUTPUT_SIZE
Definition: ripemd160.h:20
static const size_t OUTPUT_SIZE
Definition: sha256.h:21
Serialized script, used inside transaction inputs and outputs.
Definition: script.h:415
An input of a transaction.
Definition: transaction.h:67
CScript scriptSig
Definition: transaction.h:70
CScriptWitness scriptWitness
Only serialized through CTransaction.
Definition: transaction.h:72
An output of a transaction.
Definition: transaction.h:150
bool IsNull() const
Definition: transaction.h:170
An interface to be implemented by keystores that support signing.
size_t size() const
Definition: serialize.h:1086
A Span is an object that can refer to a contiguous sequence of objects.
Definition: span.h:98
CONSTEXPR_IF_NOT_DEBUG Span< C > subspan(std::size_t offset) const noexcept
Definition: span.h:195
CONSTEXPR_IF_NOT_DEBUG Span< C > first(std::size_t count) const noexcept
Definition: span.h:205
Minimal stream for reading from an existing byte array by Span.
Definition: streams.h:101
Utility class to construct Taproot outputs from internal key and script tree.
bool IsComplete() const
Return whether there were either no leaves, or the leaves form a Huffman tree.
TaprootBuilder & Add(int depth, Span< const unsigned char > script, int leaf_version, bool track=true)
Add a new script at a certain depth in the tree.
bool IsNull() const
Test whether this is the 0 key (the result of default construction).
Definition: pubkey.h:254
constexpr bool IsNull() const
Definition: uint256.h:48
bool empty() const
Definition: prevector.h:298
160-bit opaque blob.
Definition: uint256.h:189
256-bit opaque blob.
Definition: uint256.h:201
static constexpr uint8_t TAPROOT_LEAF_MASK
Definition: interpreter.h:231
@ SIGHASH_ALL
Definition: interpreter.h:30
static constexpr size_t TAPROOT_CONTROL_MAX_NODE_COUNT
Definition: interpreter.h:235
Definition: messages.h:20
TransactionError
Definition: types.h:20
#define X(name)
Definition: net.cpp:607
static constexpr TransactionSerParams TX_NO_WITNESS
Definition: transaction.h:196
static constexpr TransactionSerParams TX_WITH_WITNESS
Definition: transaction.h:195
std::shared_ptr< const CTransaction > CTransactionRef
Definition: transaction.h:423
void SerializeToVector(Stream &s, const X &... args)
Definition: psbt.h:94
static constexpr uint8_t PSBT_IN_RIPEMD160
Definition: psbt.h:43
void UpdatePSBTOutput(const SigningProvider &provider, PartiallySignedTransaction &psbt, int index)
Updates a PSBTOutput with information from provider.
Definition: psbt.cpp:338
static constexpr uint8_t PSBT_IN_HASH256
Definition: psbt.h:46
static constexpr uint8_t PSBT_GLOBAL_UNSIGNED_TX
Definition: psbt.h:28
static constexpr uint8_t PSBT_IN_NON_WITNESS_UTXO
Definition: psbt.h:34
bool PSBTInputSignedAndVerified(const PartiallySignedTransaction psbt, unsigned int input_index, const PrecomputedTransactionData *txdata)
Checks whether a PSBTInput is already signed by doing script verification using final fields.
Definition: psbt.cpp:298
static constexpr uint8_t PSBT_IN_TAP_KEY_SIG
Definition: psbt.h:47
void UnserializeFromVector(Stream &s, X &&... args)
Definition: psbt.h:104
static constexpr uint8_t PSBT_IN_SCRIPTSIG
Definition: psbt.h:41
static constexpr uint8_t PSBT_IN_WITNESSSCRIPT
Definition: psbt.h:39
std::string PSBTRoleName(PSBTRole role)
Definition: psbt.cpp:524
static constexpr uint8_t PSBT_OUT_REDEEMSCRIPT
Definition: psbt.h:56
static constexpr uint8_t PSBT_GLOBAL_VERSION
Definition: psbt.h:30
static constexpr uint8_t PSBT_IN_TAP_LEAF_SCRIPT
Definition: psbt.h:49
bool CombinePSBTs(PartiallySignedTransaction &out, const std::vector< PartiallySignedTransaction > &psbtxs)
Combines PSBTs with the same underlying transaction, resulting in a single PSBT with all partial sign...
Definition: psbt.cpp:511
static constexpr uint8_t PSBT_OUT_PROPRIETARY
Definition: psbt.h:62
static constexpr uint8_t PSBT_MAGIC_BYTES[5]
Definition: psbt.h:25
static constexpr uint32_t PSBT_HIGHEST_VERSION
Definition: psbt.h:73
static constexpr uint8_t PSBT_SEPARATOR
Definition: psbt.h:66
static constexpr uint8_t PSBT_IN_BIP32_DERIVATION
Definition: psbt.h:40
static constexpr uint8_t PSBT_IN_SCRIPTWITNESS
Definition: psbt.h:42
static constexpr uint8_t PSBT_OUT_TAP_TREE
Definition: psbt.h:60
static constexpr uint8_t PSBT_OUT_BIP32_DERIVATION
Definition: psbt.h:58
PSBTRole
Definition: psbt.h:1215
static constexpr uint8_t PSBT_GLOBAL_PROPRIETARY
Definition: psbt.h:31
bool DecodeRawPSBT(PartiallySignedTransaction &decoded_psbt, Span< const std::byte > raw_psbt, std::string &error)
Decode a raw (binary blob) PSBT into a PartiallySignedTransaction.
Definition: psbt.cpp:546
static constexpr uint8_t PSBT_IN_PROPRIETARY
Definition: psbt.h:53
KeyOriginInfo DeserializeKeyOrigin(Stream &s, uint64_t length)
Definition: psbt.h:117
static constexpr uint8_t PSBT_IN_TAP_SCRIPT_SIG
Definition: psbt.h:48
void SerializeHDKeypaths(Stream &s, const std::map< CPubKey, KeyOriginInfo > &hd_keypaths, CompactSizeWriter type)
Definition: psbt.h:185
static constexpr uint8_t PSBT_IN_TAP_BIP32_DERIVATION
Definition: psbt.h:50
static constexpr uint8_t PSBT_IN_HASH160
Definition: psbt.h:45
static constexpr uint8_t PSBT_IN_REDEEMSCRIPT
Definition: psbt.h:38
bool DecodeBase64PSBT(PartiallySignedTransaction &decoded_psbt, const std::string &base64_psbt, std::string &error)
Decode a base64ed PSBT into a PartiallySignedTransaction.
Definition: psbt.cpp:536
static constexpr uint8_t PSBT_OUT_WITNESSSCRIPT
Definition: psbt.h:57
static constexpr uint8_t PSBT_GLOBAL_XPUB
Definition: psbt.h:29
bool SignPSBTInput(const SigningProvider &provider, PartiallySignedTransaction &psbt, int index, const PrecomputedTransactionData *txdata, int sighash=SIGHASH_ALL, SignatureData *out_sigdata=nullptr, bool finalize=true)
Signs a PSBTInput, verifying that all provided data matches what is being signed.
Definition: psbt.cpp:375
static constexpr uint8_t PSBT_OUT_TAP_BIP32_DERIVATION
Definition: psbt.h:61
static constexpr uint8_t PSBT_IN_PARTIAL_SIG
Definition: psbt.h:36
static constexpr uint8_t PSBT_IN_TAP_INTERNAL_KEY
Definition: psbt.h:51
size_t CountPSBTUnsignedInputs(const PartiallySignedTransaction &psbt)
Counts the unsigned inputs of a PSBT.
Definition: psbt.cpp:327
bool FinalizeAndExtractPSBT(PartiallySignedTransaction &psbtx, CMutableTransaction &result)
Finalizes a PSBT if possible, and extracts it to a CMutableTransaction if it could be finalized.
Definition: psbt.cpp:495
static constexpr uint8_t PSBT_OUT_TAP_INTERNAL_KEY
Definition: psbt.h:59
void RemoveUnnecessaryTransactions(PartiallySignedTransaction &psbtx, const int &sighash_type)
Reduces the size of the PSBT by dropping unnecessary non_witness_utxos (i.e.
Definition: psbt.cpp:448
static constexpr uint8_t PSBT_IN_TAP_MERKLE_ROOT
Definition: psbt.h:52
void SerializeKeyOrigin(Stream &s, KeyOriginInfo hd_keypath)
Definition: psbt.h:167
void DeserializeHDKeypaths(Stream &s, const std::vector< unsigned char > &key, std::map< CPubKey, KeyOriginInfo > &hd_keypaths)
Definition: psbt.h:143
static constexpr uint8_t PSBT_IN_SIGHASH
Definition: psbt.h:37
bool PSBTInputSigned(const PSBTInput &input)
Checks whether a PSBTInput is already signed by checking for non-null finalized fields.
Definition: psbt.cpp:293
void SerializeHDKeypath(Stream &s, KeyOriginInfo hd_keypath)
Definition: psbt.h:177
PrecomputedTransactionData PrecomputePSBTData(const PartiallySignedTransaction &psbt)
Compute a PrecomputedTransactionData object from a psbt.
Definition: psbt.cpp:358
void DeserializeHDKeypath(Stream &s, KeyOriginInfo &hd_keypath)
Definition: psbt.h:136
bool FinalizePSBT(PartiallySignedTransaction &psbtx)
Finalizes a PSBT if possible, combining partial signatures.
Definition: psbt.cpp:480
const std::streamsize MAX_FILE_SIZE_PSBT
Definition: psbt.h:70
static constexpr uint8_t PSBT_IN_WITNESS_UTXO
Definition: psbt.h:35
static constexpr uint8_t PSBT_IN_SHA256
Definition: psbt.h:44
const unsigned int BIP32_EXTKEY_WITH_VERSION_SIZE
Definition: pubkey.h:20
std::vector< unsigned char > ToByteVector(const T &in)
Definition: script.h:67
void SerializeMany(Stream &s, const Args &... args)
Support for (un)serializing many things at once.
Definition: serialize.h:994
void UnserializeMany(Stream &s, Args &&... args)
Definition: serialize.h:1000
void WriteCompactSize(SizeComputer &os, uint64_t nSize)
Definition: serialize.h:1097
uint64_t ReadCompactSize(Stream &is, bool range_check=true)
Decode a CompactSize-encoded variable-length integer.
Definition: serialize.h:339
std::pair< CPubKey, std::vector< unsigned char > > SigPair
Definition: sign.h:63
void DecodeWithVersion(const unsigned char code[BIP32_EXTKEY_WITH_VERSION_SIZE])
Definition: pubkey.cpp:400
CPubKey pubkey
Definition: pubkey.h:348
A mutable version of CTransaction.
Definition: transaction.h:378
std::vector< std::vector< unsigned char > > stack
Definition: script.h:588
bool IsNull() const
Definition: script.h:593
unsigned char fingerprint[4]
First 32 bits of the Hash160 of the public key at the root of the path.
Definition: keyorigin.h:13
std::vector< uint32_t > path
Definition: keyorigin.h:14
A structure for PSBTs which contain per-input information.
Definition: psbt.h:198
std::vector< unsigned char > m_tap_key_sig
Definition: psbt.h:213
std::map< CPubKey, KeyOriginInfo > hd_keypaths
Definition: psbt.h:205
PSBTInput(deserialize_type, Stream &s)
Definition: psbt.h:708
std::map< uint256, std::vector< unsigned char > > hash256_preimages
Definition: psbt.h:210
CScriptWitness final_script_witness
Definition: psbt.h:204
std::map< std::pair< std::vector< unsigned char >, int >, std::set< std::vector< unsigned char >, ShortestVectorFirstComparator > > m_tap_scripts
Definition: psbt.h:215
CTransactionRef non_witness_utxo
Definition: psbt.h:199
std::map< CKeyID, SigPair > partial_sigs
Definition: psbt.h:206
std::optional< int > sighash_type
Definition: psbt.h:222
std::map< std::pair< XOnlyPubKey, uint256 >, std::vector< unsigned char > > m_tap_script_sigs
Definition: psbt.h:214
void Serialize(Stream &s) const
Definition: psbt.h:231
uint256 m_tap_merkle_root
Definition: psbt.h:218
std::map< uint256, std::vector< unsigned char > > sha256_preimages
Definition: psbt.h:208
void FillSignatureData(SignatureData &sigdata) const
Definition: psbt.cpp:94
std::map< uint160, std::vector< unsigned char > > hash160_preimages
Definition: psbt.h:209
bool IsNull() const
Definition: psbt.cpp:89
void Merge(const PSBTInput &input)
Definition: psbt.cpp:198
void Unserialize(Stream &s)
Definition: psbt.h:370
PSBTInput()=default
std::set< PSBTProprietary > m_proprietary
Definition: psbt.h:221
CScript redeem_script
Definition: psbt.h:201
CScript final_script_sig
Definition: psbt.h:203
void FromSignatureData(const SignatureData &sigdata)
Definition: psbt.cpp:151
XOnlyPubKey m_tap_internal_key
Definition: psbt.h:217
std::map< XOnlyPubKey, std::pair< std::set< uint256 >, KeyOriginInfo > > m_tap_bip32_paths
Definition: psbt.h:216
std::map< std::vector< unsigned char >, std::vector< unsigned char > > unknown
Definition: psbt.h:220
std::map< uint160, std::vector< unsigned char > > ripemd160_preimages
Definition: psbt.h:207
CTxOut witness_utxo
Definition: psbt.h:200
CScript witness_script
Definition: psbt.h:202
A structure for PSBTs which contains per output information.
Definition: psbt.h:715
XOnlyPubKey m_tap_internal_key
Definition: psbt.h:719
std::map< XOnlyPubKey, std::pair< std::set< uint256 >, KeyOriginInfo > > m_tap_bip32_paths
Definition: psbt.h:721
CScript witness_script
Definition: psbt.h:717
bool IsNull() const
Definition: psbt.cpp:276
void Merge(const PSBTOutput &output)
Definition: psbt.cpp:281
std::set< PSBTProprietary > m_proprietary
Definition: psbt.h:723
CScript redeem_script
Definition: psbt.h:716
void Serialize(Stream &s) const
Definition: psbt.h:732
PSBTOutput(deserialize_type, Stream &s)
Definition: psbt.h:944
std::map< CPubKey, KeyOriginInfo > hd_keypaths
Definition: psbt.h:718
PSBTOutput()=default
std::vector< std::tuple< uint8_t, uint8_t, std::vector< unsigned char > > > m_tap_tree
Definition: psbt.h:720
void Unserialize(Stream &s)
Definition: psbt.h:795
std::map< std::vector< unsigned char >, std::vector< unsigned char > > unknown
Definition: psbt.h:722
void FillSignatureData(SignatureData &sigdata) const
Definition: psbt.cpp:225
void FromSignatureData(const SignatureData &sigdata)
Definition: psbt.cpp:254
A structure for PSBT proprietary types.
Definition: psbt.h:77
std::vector< unsigned char > value
Definition: psbt.h:81
bool operator<(const PSBTProprietary &b) const
Definition: psbt.h:83
uint64_t subtype
Definition: psbt.h:78
std::vector< unsigned char > identifier
Definition: psbt.h:79
std::vector< unsigned char > key
Definition: psbt.h:80
bool operator==(const PSBTProprietary &b) const
Definition: psbt.h:86
A version of CTransaction with the PSBT format.
Definition: psbt.h:951
uint32_t GetVersion() const
Definition: psbt.cpp:562
bool Merge(const PartiallySignedTransaction &psbt)
Merge psbt into this.
Definition: psbt.cpp:24
std::map< KeyOriginInfo, std::set< CExtPubKey > > m_xpubs
Definition: psbt.h:955
std::optional< uint32_t > m_version
Definition: psbt.h:959
bool IsNull() const
Definition: psbt.cpp:19
bool GetInputUTXO(CTxOut &utxo, int input_index) const
Finds the UTXO for a given input index.
Definition: psbt.cpp:69
std::map< std::vector< unsigned char >, std::vector< unsigned char > > unknown
Definition: psbt.h:958
bool AddOutput(const CTxOut &txout, const PSBTOutput &psbtout)
Definition: psbt.cpp:62
std::vector< PSBTInput > inputs
Definition: psbt.h:956
PartiallySignedTransaction()=default
std::optional< CMutableTransaction > tx
Definition: psbt.h:952
bool AddInput(const CTxIn &txin, PSBTInput &psbtin)
Definition: psbt.cpp:49
std::vector< PSBTOutput > outputs
Definition: psbt.h:957
std::set< PSBTProprietary > m_proprietary
Definition: psbt.h:960
void Serialize(Stream &s) const
Definition: psbt.h:982
PartiallySignedTransaction(deserialize_type, Stream &s)
Definition: psbt.h:1210
void Unserialize(Stream &s)
Definition: psbt.h:1038
Dummy data type to identify deserializing constructors.
Definition: serialize.h:48