Bitcoin Core 31.99.0
P2P Digital Currency
psbt.h
Go to the documentation of this file.
1// Copyright (c) 2009-present 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 <common/types.h>
9#include <musig.h>
10#include <node/transaction.h>
11#include <policy/feerate.h>
13#include <pubkey.h>
14#include <script/keyorigin.h>
15#include <script/sign.h>
17#include <span.h>
18#include <streams.h>
19#include <uint256.h>
20#include <util/result.h>
21
22#include <optional>
23#include <bitset>
24
25namespace node {
26enum class TransactionError;
27} // namespace node
28
30
31// Magic bytes
32static constexpr uint8_t PSBT_MAGIC_BYTES[5] = {'p', 's', 'b', 't', 0xff};
33
34// Global types
35static constexpr uint8_t PSBT_GLOBAL_UNSIGNED_TX = 0x00;
36static constexpr uint8_t PSBT_GLOBAL_XPUB = 0x01;
37static constexpr uint8_t PSBT_GLOBAL_TX_VERSION = 0x02;
38static constexpr uint8_t PSBT_GLOBAL_FALLBACK_LOCKTIME = 0x03;
39static constexpr uint8_t PSBT_GLOBAL_INPUT_COUNT = 0x04;
40static constexpr uint8_t PSBT_GLOBAL_OUTPUT_COUNT = 0x05;
41static constexpr uint8_t PSBT_GLOBAL_TX_MODIFIABLE = 0x06;
42static constexpr uint8_t PSBT_GLOBAL_VERSION = 0xFB;
43static constexpr uint8_t PSBT_GLOBAL_PROPRIETARY = 0xFC;
44
45// Input types
46static constexpr uint8_t PSBT_IN_NON_WITNESS_UTXO = 0x00;
47static constexpr uint8_t PSBT_IN_WITNESS_UTXO = 0x01;
48static constexpr uint8_t PSBT_IN_PARTIAL_SIG = 0x02;
49static constexpr uint8_t PSBT_IN_SIGHASH = 0x03;
50static constexpr uint8_t PSBT_IN_REDEEMSCRIPT = 0x04;
51static constexpr uint8_t PSBT_IN_WITNESSSCRIPT = 0x05;
52static constexpr uint8_t PSBT_IN_BIP32_DERIVATION = 0x06;
53static constexpr uint8_t PSBT_IN_SCRIPTSIG = 0x07;
54static constexpr uint8_t PSBT_IN_SCRIPTWITNESS = 0x08;
55static constexpr uint8_t PSBT_IN_RIPEMD160 = 0x0A;
56static constexpr uint8_t PSBT_IN_SHA256 = 0x0B;
57static constexpr uint8_t PSBT_IN_HASH160 = 0x0C;
58static constexpr uint8_t PSBT_IN_HASH256 = 0x0D;
59static constexpr uint8_t PSBT_IN_PREVIOUS_TXID = 0x0e;
60static constexpr uint8_t PSBT_IN_OUTPUT_INDEX = 0x0f;
61static constexpr uint8_t PSBT_IN_SEQUENCE = 0x10;
62static constexpr uint8_t PSBT_IN_REQUIRED_TIME_LOCKTIME = 0x11;
63static constexpr uint8_t PSBT_IN_REQUIRED_HEIGHT_LOCKTIME = 0x12;
64static constexpr uint8_t PSBT_IN_TAP_KEY_SIG = 0x13;
65static constexpr uint8_t PSBT_IN_TAP_SCRIPT_SIG = 0x14;
66static constexpr uint8_t PSBT_IN_TAP_LEAF_SCRIPT = 0x15;
67static constexpr uint8_t PSBT_IN_TAP_BIP32_DERIVATION = 0x16;
68static constexpr uint8_t PSBT_IN_TAP_INTERNAL_KEY = 0x17;
69static constexpr uint8_t PSBT_IN_TAP_MERKLE_ROOT = 0x18;
70static constexpr uint8_t PSBT_IN_MUSIG2_PARTICIPANT_PUBKEYS = 0x1a;
71static constexpr uint8_t PSBT_IN_MUSIG2_PUB_NONCE = 0x1b;
72static constexpr uint8_t PSBT_IN_MUSIG2_PARTIAL_SIG = 0x1c;
73static constexpr uint8_t PSBT_IN_PROPRIETARY = 0xFC;
74
75// Output types
76static constexpr uint8_t PSBT_OUT_REDEEMSCRIPT = 0x00;
77static constexpr uint8_t PSBT_OUT_WITNESSSCRIPT = 0x01;
78static constexpr uint8_t PSBT_OUT_BIP32_DERIVATION = 0x02;
79static constexpr uint8_t PSBT_OUT_AMOUNT = 0x03;
80static constexpr uint8_t PSBT_OUT_SCRIPT = 0x04;
81static constexpr uint8_t PSBT_OUT_TAP_INTERNAL_KEY = 0x05;
82static constexpr uint8_t PSBT_OUT_TAP_TREE = 0x06;
83static constexpr uint8_t PSBT_OUT_TAP_BIP32_DERIVATION = 0x07;
84static constexpr uint8_t PSBT_OUT_MUSIG2_PARTICIPANT_PUBKEYS = 0x08;
85static constexpr uint8_t PSBT_OUT_PROPRIETARY = 0xFC;
86
87// The separator is 0x00. Reading this in means that the unserializer can interpret it
88// as a 0 length key which indicates that this is the separator. The separator has no value.
89static constexpr uint8_t PSBT_SEPARATOR = 0x00;
90
91// BIP 174 does not specify a maximum file size, but we set a limit anyway
92// to prevent reading a stream indefinitely and running out of memory.
93const std::streamsize MAX_FILE_SIZE_PSBT = 100000000; // 100 MB
94
95// PSBT version number
96static constexpr uint32_t PSBT_HIGHEST_VERSION = 2;
97
100{
101 uint64_t subtype;
102 std::vector<unsigned char> identifier;
103 std::vector<unsigned char> key;
104 std::vector<unsigned char> value;
105
106 bool operator<(const PSBTProprietary &b) const {
107 return key < b.key;
108 }
109 bool operator==(const PSBTProprietary &b) const {
110 return key == b.key;
111 }
112};
113
114// Takes a stream and multiple arguments and serializes them as if first serialized into a vector and then into the stream
115// The resulting output into the stream has the total serialized length of all of the objects followed by all objects concatenated with each other.
116template<typename Stream, typename... X>
117void SerializeToVector(Stream& s, const X&... args)
118{
119 SizeComputer sizecomp;
120 SerializeMany(sizecomp, args...);
121 WriteCompactSize(s, sizecomp.size());
122 SerializeMany(s, args...);
123}
124
125// Takes a stream and multiple arguments and unserializes them first as a vector then each object individually in the order provided in the arguments
126template<typename Stream, typename... X>
127void UnserializeFromVector(Stream& s, X&&... args)
128{
129 size_t expected_size = ReadCompactSize(s);
130 size_t remaining_before = s.size();
132 size_t remaining_after = s.size();
133 if (remaining_after + expected_size != remaining_before) {
134 throw std::ios_base::failure("Size of value was not the stated size");
135 }
136}
137
138// Deserialize bytes of given length from the stream as a KeyOriginInfo
139template<typename Stream>
140KeyOriginInfo DeserializeKeyOrigin(Stream& s, uint64_t length)
141{
142 // Read in key path
143 if (length % 4 || length == 0) {
144 throw std::ios_base::failure("Invalid length for HD key path");
145 }
146
147 KeyOriginInfo hd_keypath;
148 s >> hd_keypath.fingerprint;
149 for (unsigned int i = 4; i < length; i += sizeof(uint32_t)) {
150 uint32_t index;
151 s >> index;
152 hd_keypath.path.push_back(index);
153 }
154 return hd_keypath;
155}
156
157// Deserialize a length prefixed KeyOriginInfo from a stream
158template<typename Stream>
159void DeserializeHDKeypath(Stream& s, KeyOriginInfo& hd_keypath)
160{
161 hd_keypath = DeserializeKeyOrigin(s, ReadCompactSize(s));
162}
163
164// Deserialize HD keypaths into a map
165template<typename Stream>
166void DeserializeHDKeypaths(Stream& s, const std::vector<unsigned char>& key, std::map<CPubKey, KeyOriginInfo>& hd_keypaths)
167{
168 // Make sure that the key is the size of pubkey + 1
169 if (key.size() != CPubKey::SIZE + 1 && key.size() != CPubKey::COMPRESSED_SIZE + 1) {
170 throw std::ios_base::failure("Size of key was not the expected size for the type BIP32 keypath");
171 }
172 // Read in the pubkey from key
173 CPubKey pubkey(key.begin() + 1, key.end());
174 if (!pubkey.IsFullyValid()) {
175 throw std::ios_base::failure("Invalid pubkey");
176 }
177
178 KeyOriginInfo keypath;
179 DeserializeHDKeypath(s, keypath);
180
181 // Add to map
182 hd_keypaths.emplace(pubkey, std::move(keypath));
183}
184
185// Serialize a KeyOriginInfo to a stream
186template<typename Stream>
187void SerializeKeyOrigin(Stream& s, KeyOriginInfo hd_keypath)
188{
189 s << hd_keypath.fingerprint;
190 for (const auto& path : hd_keypath.path) {
191 s << path;
192 }
193}
194
195// Serialize a length prefixed KeyOriginInfo to a stream
196template<typename Stream>
197void SerializeHDKeypath(Stream& s, KeyOriginInfo hd_keypath)
198{
199 WriteCompactSize(s, (hd_keypath.path.size() + 1) * sizeof(uint32_t));
200 SerializeKeyOrigin(s, hd_keypath);
201}
202
203// Serialize HD keypaths to a stream from a map
204template<typename Stream>
205void SerializeHDKeypaths(Stream& s, const std::map<CPubKey, KeyOriginInfo>& hd_keypaths, CompactSizeWriter type)
206{
207 for (const auto& keypath_pair : hd_keypaths) {
208 if (!keypath_pair.first.IsValid()) {
209 throw std::ios_base::failure("Invalid CPubKey being serialized");
210 }
211 SerializeToVector(s, type, std::span{keypath_pair.first});
212 SerializeHDKeypath(s, keypath_pair.second);
213 }
214}
215
216// Deserialize a PSBT_{IN/OUT}_MUSIG2_PARTICIPANT_PUBKEYS field
217template<typename Stream>
218void DeserializeMuSig2ParticipantPubkeys(Stream& s, SpanReader& skey, std::map<CPubKey, std::vector<CPubKey>>& out, std::string context)
219{
220 std::array<unsigned char, CPubKey::COMPRESSED_SIZE> agg_pubkey_bytes;
221 skey >> std::as_writable_bytes(std::span{agg_pubkey_bytes});
222 CPubKey agg_pubkey(agg_pubkey_bytes);
223 if (!agg_pubkey.IsFullyValid()) {
224 throw std::ios_base::failure(context + " musig2 aggregate pubkey is invalid");
225 }
226
227 std::vector<CPubKey> participants;
228 std::vector<unsigned char> val;
229 s >> val;
230 SpanReader s_val{val};
231 while (s_val.size() >= CPubKey::COMPRESSED_SIZE) {
232 std::array<unsigned char, CPubKey::COMPRESSED_SIZE> part_pubkey_bytes;
233 s_val >> std::as_writable_bytes(std::span{part_pubkey_bytes});
234 CPubKey participant(part_pubkey_bytes);
235 if (!participant.IsFullyValid()) {
236 throw std::ios_base::failure(context + " musig2 participant pubkey is invalid");
237 }
238 participants.push_back(participant);
239 }
240 if (!s_val.empty()) {
241 throw std::ios_base::failure(context + " musig2 participants pubkeys value size is not a multiple of 33");
242 }
243
244 out.emplace(agg_pubkey, participants);
245}
246
247// Deserialize the MuSig2 participant identifiers from PSBT_MUSIG2_{PUBNONCE/PARTIAL_SIG} fields
248// Both fields contain the same data after the type byte - aggregate pubkey | participant pubkey | leaf script hash
249template<typename Stream>
250void DeserializeMuSig2ParticipantDataIdentifier(Stream& skey, CPubKey& agg_pub, CPubKey& part_pub, uint256& leaf_hash)
251{
252 leaf_hash.SetNull();
253
254 std::array<unsigned char, CPubKey::COMPRESSED_SIZE> part_pubkey_bytes;
255 std::array<unsigned char, CPubKey::COMPRESSED_SIZE> agg_pubkey_bytes;
256
257 skey >> std::as_writable_bytes(std::span{part_pubkey_bytes}) >> std::as_writable_bytes(std::span{agg_pubkey_bytes});
258 agg_pub.Set(agg_pubkey_bytes.begin(), agg_pubkey_bytes.end());
259 if (!agg_pub.IsFullyValid()) {
260 throw std::ios_base::failure("musig2 aggregate pubkey is invalid");
261 }
262
263 part_pub.Set(part_pubkey_bytes.begin(), part_pubkey_bytes.end());
264 if (!part_pub.IsFullyValid()) {
265 throw std::ios_base::failure("musig2 participant pubkey is invalid");
266 }
267
268 if (!skey.empty()) {
269 skey >> leaf_hash;
270 }
271}
272
273static inline void ExpectedKeySize(const std::string& key_name, const std::vector<unsigned char>& key, uint64_t expected_size) {
274 if (key.size() != expected_size) {
275 throw std::ios_base::failure(tfm::format("Size of key was not %d for the type %s", expected_size, key_name));
276 }
277}
278
281{
282private:
284
285public:
292 std::map<CPubKey, KeyOriginInfo> hd_keypaths;
293 std::map<CKeyID, SigPair> partial_sigs;
294 std::map<uint160, std::vector<unsigned char>> ripemd160_preimages;
295 std::map<uint256, std::vector<unsigned char>> sha256_preimages;
296 std::map<uint160, std::vector<unsigned char>> hash160_preimages;
297 std::map<uint256, std::vector<unsigned char>> hash256_preimages;
298
300 uint32_t prev_out;
301 std::optional<uint32_t> sequence;
302 std::optional<uint32_t> time_locktime;
303 std::optional<uint32_t> height_locktime;
304
305 // Taproot fields
306 std::vector<unsigned char> m_tap_key_sig;
307 std::map<std::pair<XOnlyPubKey, uint256>, std::vector<unsigned char>> m_tap_script_sigs;
308 std::map<std::pair<std::vector<unsigned char>, int>, std::set<std::vector<unsigned char>, ShortestVectorFirstComparator>> m_tap_scripts;
309 std::map<XOnlyPubKey, std::pair<std::set<uint256>, KeyOriginInfo>> m_tap_bip32_paths;
312
313 // MuSig2 fields
314 std::map<CPubKey, std::vector<CPubKey>> m_musig2_participants;
315 // Key is the aggregate pubkey and the script leaf hash, value is a map of participant pubkey to pubnonce
316 std::map<std::pair<CPubKey, uint256>, std::map<CPubKey, std::vector<uint8_t>>> m_musig2_pubnonces;
317 // Key is the aggregate pubkey and the script leaf hash, value is a map of participant pubkey to partial_sig
318 std::map<std::pair<CPubKey, uint256>, std::map<CPubKey, uint256>> m_musig2_partial_sigs;
319
320 std::map<std::vector<unsigned char>, std::vector<unsigned char>> unknown;
321 std::set<PSBTProprietary> m_proprietary;
322 std::optional<int> sighash_type;
323
324 bool IsNull() const;
325 void FillSignatureData(SignatureData& sigdata) const;
326 void FromSignatureData(const SignatureData& sigdata);
327 [[nodiscard]] bool Merge(const PSBTInput& input);
328 uint32_t GetVersion() const { return m_psbt_version; }
329 COutPoint GetOutPoint() const;
336 bool GetUTXO(CTxOut& utxo) const;
337 bool HasSignatures() const;
338
339 explicit PSBTInput(uint32_t psbt_version, const Txid& prev_txid, uint32_t prev_out, std::optional<uint32_t> sequence = std::nullopt)
340 : m_psbt_version(psbt_version),
344 {
346 }
347
348 // Construct a PSBTInput when the previous txid and output index are expected to be serialized
349 template <typename Stream>
350 explicit PSBTInput(deserialize_type, Stream& s, uint32_t psbt_version)
351 : m_psbt_version(psbt_version)
352 {
354 Unserialize(s);
355 }
356
357 bool operator==(const PSBTInput&) const = default;
358
359 template <typename Stream>
360 inline void Serialize(Stream& s) const {
361 // Write the utxo
362 if (non_witness_utxo) {
365 }
366 if (!witness_utxo.IsNull()) {
369 }
370
372 // Write any partial signatures
373 for (const auto& sig_pair : partial_sigs) {
374 SerializeToVector(s, CompactSizeWriter(PSBT_IN_PARTIAL_SIG), std::span{sig_pair.second.first});
375 s << sig_pair.second.second;
376 }
377
378 // Write the sighash type
379 if (sighash_type != std::nullopt) {
382 }
383
384 // Write the redeem script
385 if (!redeem_script.empty()) {
387 s << redeem_script;
388 }
389
390 // Write the witness script
391 if (!witness_script.empty()) {
393 s << witness_script;
394 }
395
396 // Write any hd keypaths
398
399 // Write any ripemd160 preimage
400 for (const auto& [hash, preimage] : ripemd160_preimages) {
402 s << preimage;
403 }
404
405 // Write any sha256 preimage
406 for (const auto& [hash, preimage] : sha256_preimages) {
408 s << preimage;
409 }
410
411 // Write any hash160 preimage
412 for (const auto& [hash, preimage] : hash160_preimages) {
414 s << preimage;
415 }
416
417 // Write any hash256 preimage
418 for (const auto& [hash, preimage] : hash256_preimages) {
420 s << preimage;
421 }
422
423 // Write taproot key sig
424 if (!m_tap_key_sig.empty()) {
426 s << m_tap_key_sig;
427 }
428
429 // Write taproot script sigs
430 for (const auto& [pubkey_leaf, sig] : m_tap_script_sigs) {
431 const auto& [xonly, leaf_hash] = pubkey_leaf;
432 SerializeToVector(s, PSBT_IN_TAP_SCRIPT_SIG, xonly, leaf_hash);
433 s << sig;
434 }
435
436 // Write taproot leaf scripts
437 for (const auto& [leaf, control_blocks] : m_tap_scripts) {
438 const auto& [script, leaf_ver] = leaf;
439 for (const auto& control_block : control_blocks) {
440 SerializeToVector(s, PSBT_IN_TAP_LEAF_SCRIPT, std::span{control_block});
441 std::vector<unsigned char> value_v(script.begin(), script.end());
442 value_v.push_back((uint8_t)leaf_ver);
443 s << value_v;
444 }
445 }
446
447 // Write taproot bip32 keypaths
448 for (const auto& [xonly, leaf_origin] : m_tap_bip32_paths) {
449 const auto& [leaf_hashes, origin] = leaf_origin;
451 std::vector<unsigned char> value;
452 VectorWriter s_value{value, 0};
453 s_value << leaf_hashes;
454 SerializeKeyOrigin(s_value, origin);
455 s << value;
456 }
457
458 // Write taproot internal key
459 if (!m_tap_internal_key.IsNull()) {
462 }
463
464 // Write taproot merkle root
465 if (!m_tap_merkle_root.IsNull()) {
468 }
469
470 // Write MuSig2 Participants
471 for (const auto& [agg_pubkey, part_pubs] : m_musig2_participants) {
473 std::vector<unsigned char> value;
474 VectorWriter s_value{value, 0};
475 for (auto& pk : part_pubs) {
476 s_value << std::span{pk};
477 }
478 s << value;
479 }
480
481 // Write MuSig2 pubnonces
482 for (const auto& [agg_pubkey_leaf_hash, pubnonces] : m_musig2_pubnonces) {
483 const auto& [agg_pubkey, leaf_hash] = agg_pubkey_leaf_hash;
484 for (const auto& [part_pubkey, pubnonce] : pubnonces) {
485 if (leaf_hash.IsNull()) {
486 SerializeToVector(s, CompactSizeWriter(PSBT_IN_MUSIG2_PUB_NONCE), std::span{part_pubkey}, std::span{agg_pubkey});
487 } else {
488 SerializeToVector(s, CompactSizeWriter(PSBT_IN_MUSIG2_PUB_NONCE), std::span{part_pubkey}, std::span{agg_pubkey}, leaf_hash);
489 }
490 s << pubnonce;
491 }
492 }
493
494 // Write MuSig2 partial signatures
495 for (const auto& [agg_pubkey_leaf_hash, psigs] : m_musig2_partial_sigs) {
496 const auto& [agg_pubkey, leaf_hash] = agg_pubkey_leaf_hash;
497 for (const auto& [pubkey, psig] : psigs) {
498 if (leaf_hash.IsNull()) {
499 SerializeToVector(s, CompactSizeWriter(PSBT_IN_MUSIG2_PARTIAL_SIG), std::span{pubkey}, std::span{agg_pubkey});
500 } else {
501 SerializeToVector(s, CompactSizeWriter(PSBT_IN_MUSIG2_PARTIAL_SIG), std::span{pubkey}, std::span{agg_pubkey}, leaf_hash);
502 }
503 SerializeToVector(s, psig);
504 }
505 }
506 }
507
508 // Write script sig
509 if (!final_script_sig.empty()) {
512 }
513 // write script witness
517 }
518
519 // Write PSBTv2 fields
520 if (m_psbt_version >= 2) {
521 // Write prev txid, vout, sequence, and lock times
524
527
528 if (sequence != std::nullopt) {
531 }
532 if (time_locktime != std::nullopt) {
535 }
536 if (height_locktime != std::nullopt) {
539 }
540 }
541
542 // Write proprietary things
543 for (const auto& entry : m_proprietary) {
544 s << entry.key;
545 s << entry.value;
546 }
547
548 // Write unknown things
549 for (auto& entry : unknown) {
550 s << entry.first;
551 s << entry.second;
552 }
553
554 s << PSBT_SEPARATOR;
555 }
556
557
558 template <typename Stream>
559 inline void Unserialize(Stream& s) {
560 // Used for duplicate key detection
561 std::set<std::vector<unsigned char>> key_lookup;
562 // Cache whether PSBTv2 required fields were seen
563 bool found_prev_txid = false;
564 bool found_prev_out = false;
565
566 // Read loop
567 bool found_sep = false;
568 while(!s.empty()) {
569 // Read the key of format "<keylen><keytype><keydata>" after which
570 // "key" will contain "<keytype><keydata>"
571 std::vector<unsigned char> key;
572 s >> key;
573
574 // the key is empty if that was actually a separator byte
575 // This is a special case for key lengths 0 as those are not allowed (except for separator)
576 if (key.empty()) {
577 found_sep = true;
578 break;
579 }
580
581 // Duplicate keys are not permitted
582 if (!key_lookup.emplace(key).second) {
583 throw std::ios_base::failure(tfm::format("Duplicate Key, input key \"%s\" already provided", HexStr(key)));
584 }
585
586 // "skey" is used so that "key" is unchanged after reading keytype below
587 SpanReader skey{key};
588 // keytype is of the format compact size uint at the beginning of "key"
589 uint64_t type = ReadCompactSize(skey);
590
591 // Do stuff based on keytype "type", i.e., key checks, reading values of the
592 // format "<valuelen><valuedata>" from the stream "s", and value checks
593 switch(type) {
595 {
596 ExpectedKeySize("Input Non-witness UTXO", key, 1);
597 // Set the stream to unserialize with witness since this is always a valid network transaction
599 break;
600 }
602 ExpectedKeySize("Input Witness UTXO", key, 1);
604 break;
606 {
607 // Make sure that the key is the size of pubkey + 1
608 if (key.size() != CPubKey::SIZE + 1 && key.size() != CPubKey::COMPRESSED_SIZE + 1) {
609 throw std::ios_base::failure("Size of key was not the expected size for the type partial signature pubkey");
610 }
611 // Read in the pubkey from key
612 CPubKey pubkey(key.begin() + 1, key.end());
613 if (!pubkey.IsFullyValid()) {
614 throw std::ios_base::failure("Invalid pubkey");
615 }
616
617 // Read in the signature from value
618 std::vector<unsigned char> sig;
619 s >> sig;
620
621 // Check that the signature is validly encoded
622 if (sig.empty() || !CheckSignatureEncoding(sig, SCRIPT_VERIFY_DERSIG | SCRIPT_VERIFY_STRICTENC, nullptr)) {
623 throw std::ios_base::failure("Signature is not a valid encoding");
624 }
625
626 // Add to list
627 partial_sigs.emplace(pubkey.GetID(), SigPair(pubkey, std::move(sig)));
628 break;
629 }
630 case PSBT_IN_SIGHASH:
631 ExpectedKeySize("Input Sighash Type", key, 1);
632 int sighash;
633 UnserializeFromVector(s, sighash);
634 sighash_type = sighash;
635 break;
637 {
638 ExpectedKeySize("Input redeemScript", key, 1);
639 s >> redeem_script;
640 break;
641 }
643 {
644 ExpectedKeySize("Input witnessScript", key, 1);
645 s >> witness_script;
646 break;
647 }
649 {
651 break;
652 }
654 {
655 ExpectedKeySize("Input Final scriptSig", key, 1);
657 break;
658 }
660 {
661 ExpectedKeySize("Input Final scriptWitness", key, 1);
663 break;
664 }
666 {
667 ExpectedKeySize("Input RIPEMD160 Preimage", key, CRIPEMD160::OUTPUT_SIZE + 1);
668 // Read in the hash from key
669 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
670 uint160 hash(hash_vec);
671
672 // Read in the preimage from value
673 std::vector<unsigned char> preimage;
674 s >> preimage;
675
676 // Add to preimages list
677 ripemd160_preimages.emplace(hash, std::move(preimage));
678 break;
679 }
680 case PSBT_IN_SHA256:
681 {
682 ExpectedKeySize("Input SHA256 Preimage", key, CSHA256::OUTPUT_SIZE + 1);
683 // Read in the hash from key
684 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
685 uint256 hash(hash_vec);
686
687 // Read in the preimage from value
688 std::vector<unsigned char> preimage;
689 s >> preimage;
690
691 // Add to preimages list
692 sha256_preimages.emplace(hash, std::move(preimage));
693 break;
694 }
695 case PSBT_IN_HASH160:
696 {
697 ExpectedKeySize("Input Hash160 Preimage", key, CHash160::OUTPUT_SIZE + 1);
698 // Read in the hash from key
699 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
700 uint160 hash(hash_vec);
701
702 // Read in the preimage from value
703 std::vector<unsigned char> preimage;
704 s >> preimage;
705
706 // Add to preimages list
707 hash160_preimages.emplace(hash, std::move(preimage));
708 break;
709 }
710 case PSBT_IN_HASH256:
711 {
712 ExpectedKeySize("Input Hash256 Preimage", key, CHash256::OUTPUT_SIZE + 1);
713 // Read in the hash from key
714 std::vector<unsigned char> hash_vec(key.begin() + 1, key.end());
715 uint256 hash(hash_vec);
716
717 // Read in the preimage from value
718 std::vector<unsigned char> preimage;
719 s >> preimage;
720
721 // Add to preimages list
722 hash256_preimages.emplace(hash, std::move(preimage));
723 break;
724 }
726 {
727 ExpectedKeySize("Input Previous TXID", key, 1);
728 if (m_psbt_version < 2) {
729 throw std::ios_base::failure("Previous txid is not allowed in PSBTv0");
730 }
732 found_prev_txid = true;
733 break;
734 }
736 {
737 ExpectedKeySize("Input Previous Output's Index", key, 1);
738 if (m_psbt_version < 2) {
739 throw std::ios_base::failure("Previous output's index is not allowed in PSBTv0");
740 }
742 found_prev_out = true;
743 break;
744 }
745 case PSBT_IN_SEQUENCE:
746 {
747 ExpectedKeySize("Input Sequence", key, 1);
748 if (m_psbt_version < 2) {
749 throw std::ios_base::failure("Sequence is not allowed in PSBTv0");
750 }
751 sequence.emplace();
753 break;
754 }
756 {
757 ExpectedKeySize("Input Required Time Based Locktime", key, 1);
758 if (m_psbt_version < 2) {
759 throw std::ios_base::failure("Required time based locktime is not allowed in PSBTv0");
760 }
761 time_locktime.emplace();
764 throw std::ios_base::failure("Required time based locktime is invalid (less than 500000000)");
765 }
766 break;
767 }
769 {
770 ExpectedKeySize("Input Required Height Based Locktime", key, 1);
771 if (m_psbt_version < 2) {
772 throw std::ios_base::failure("Required height based locktime is not allowed in PSBTv0");
773 }
774 height_locktime.emplace();
777 throw std::ios_base::failure("Required height based locktime is invalid (greater than or equal to 500000000)");
778 } else if (*height_locktime == 0) {
779 throw std::ios_base::failure("Required height based locktime is invalid (0)");
780 }
781 break;
782 }
784 {
785 ExpectedKeySize("Input Taproot Key Path Signature", key, 1);
786 s >> m_tap_key_sig;
787 if (m_tap_key_sig.size() < 64) {
788 throw std::ios_base::failure("Input Taproot key path signature is shorter than 64 bytes");
789 } else if (m_tap_key_sig.size() > 65) {
790 throw std::ios_base::failure("Input Taproot key path signature is longer than 65 bytes");
791 }
792 break;
793 }
795 {
796 ExpectedKeySize("Input Taproot Script Path Signature", key, 65);
797 SpanReader s_key{std::span{key}.subspan(1)};
798 XOnlyPubKey xonly;
799 uint256 hash;
800 s_key >> xonly;
801 s_key >> hash;
802 std::vector<unsigned char> sig;
803 s >> sig;
804 if (sig.size() < 64) {
805 throw std::ios_base::failure("Input Taproot script path signature is shorter than 64 bytes");
806 } else if (sig.size() > 65) {
807 throw std::ios_base::failure("Input Taproot script path signature is longer than 65 bytes");
808 }
809 m_tap_script_sigs.emplace(std::make_pair(xonly, hash), sig);
810 break;
811 }
813 {
814 if (key.size() < 34) {
815 throw std::ios_base::failure("Input Taproot leaf script key is not at least 34 bytes");
816 } else if ((key.size() - 2) % 32 != 0) {
817 throw std::ios_base::failure("Input Taproot leaf script key's control block size is not valid");
818 }
819 std::vector<unsigned char> script_v;
820 s >> script_v;
821 if (script_v.empty()) {
822 throw std::ios_base::failure("Input Taproot leaf script must be at least 1 byte");
823 }
824 uint8_t leaf_ver = script_v.back();
825 script_v.pop_back();
826 const auto leaf_script = std::make_pair(script_v, (int)leaf_ver);
827 m_tap_scripts[leaf_script].insert(std::vector<unsigned char>(key.begin() + 1, key.end()));
828 break;
829 }
831 {
832 ExpectedKeySize("Input Taproot BIP32 Keypath", key, 33);
833 SpanReader s_key{std::span{key}.subspan(1)};
834 XOnlyPubKey xonly;
835 s_key >> xonly;
836 std::set<uint256> leaf_hashes;
837 uint64_t value_len = ReadCompactSize(s);
838 size_t before_hashes = s.size();
839 s >> leaf_hashes;
840 size_t after_hashes = s.size();
841 size_t hashes_len = before_hashes - after_hashes;
842 if (hashes_len > value_len) {
843 throw std::ios_base::failure("Input Taproot BIP32 keypath has an invalid length");
844 }
845 size_t origin_len = value_len - hashes_len;
846 m_tap_bip32_paths.emplace(xonly, std::make_pair(leaf_hashes, DeserializeKeyOrigin(s, origin_len)));
847 break;
848 }
850 {
851 ExpectedKeySize("Input Taproot Internal Key", key, 1);
853 break;
854 }
856 {
857 ExpectedKeySize("Input Taproot Merkle Root", key, 1);
859 break;
860 }
862 {
863 ExpectedKeySize("Input MuSig2 Participants Pubkeys", key, CPubKey::COMPRESSED_SIZE + 1);
864 DeserializeMuSig2ParticipantPubkeys(s, skey, m_musig2_participants, std::string{"Input"});
865 break;
866 }
868 {
869 if (key.size() != 2 * CPubKey::COMPRESSED_SIZE + 1 && key.size() != 2 * CPubKey::COMPRESSED_SIZE + CSHA256::OUTPUT_SIZE + 1) {
870 throw std::ios_base::failure("Input musig2 pubnonce key is not expected size of 67 or 99 bytes");
871 }
872 CPubKey agg_pub, part_pub;
873 uint256 leaf_hash;
874 DeserializeMuSig2ParticipantDataIdentifier(skey, agg_pub, part_pub, leaf_hash);
875
876 std::vector<uint8_t> pubnonce;
877 s >> pubnonce;
878 if (pubnonce.size() != MUSIG2_PUBNONCE_SIZE) {
879 throw std::ios_base::failure("Input musig2 pubnonce value is not 66 bytes");
880 }
881
882 m_musig2_pubnonces[std::make_pair(agg_pub, leaf_hash)].emplace(part_pub, pubnonce);
883 break;
884 }
886 {
887 if (key.size() != 2 * CPubKey::COMPRESSED_SIZE + 1 && key.size() != 2 * CPubKey::COMPRESSED_SIZE + CSHA256::OUTPUT_SIZE + 1) {
888 throw std::ios_base::failure("Input musig2 partial sig key is not expected size of 67 or 99 bytes");
889 }
890 CPubKey agg_pub, part_pub;
891 uint256 leaf_hash;
892 DeserializeMuSig2ParticipantDataIdentifier(skey, agg_pub, part_pub, leaf_hash);
893
894 uint256 partial_sig;
895 UnserializeFromVector(s, partial_sig);
896
897 m_musig2_partial_sigs[std::make_pair(agg_pub, leaf_hash)].emplace(part_pub, partial_sig);
898 break;
899 }
901 {
902 PSBTProprietary this_prop;
903 skey >> this_prop.identifier;
904 this_prop.subtype = ReadCompactSize(skey);
905 this_prop.key = key;
906
907 s >> this_prop.value;
908 m_proprietary.insert(this_prop);
909 break;
910 }
911 // Unknown stuff
912 default:
913 // Read in the value
914 std::vector<unsigned char> val_bytes;
915 s >> val_bytes;
916 unknown.emplace(std::move(key), std::move(val_bytes));
917 break;
918 }
919 }
920
921 if (!found_sep) {
922 throw std::ios_base::failure("Separator is missing at the end of an input map");
923 }
924
925 // Make sure required PSBTv2 fields are present
926 if (m_psbt_version >= 2) {
927 if (!found_prev_txid) {
928 throw std::ios_base::failure("Previous TXID is required in PSBTv2");
929 }
930 if (!found_prev_out) {
931 throw std::ios_base::failure("Previous output's index is required in PSBTv2");
932 }
933 }
934 }
935};
936
939{
940private:
942
943public:
946 std::map<CPubKey, KeyOriginInfo> hd_keypaths;
947
949 std::vector<std::tuple<uint8_t, uint8_t, std::vector<unsigned char>>> m_tap_tree;
950 std::map<XOnlyPubKey, std::pair<std::set<uint256>, KeyOriginInfo>> m_tap_bip32_paths;
951 std::map<CPubKey, std::vector<CPubKey>> m_musig2_participants;
952
953 std::map<std::vector<unsigned char>, std::vector<unsigned char>> unknown;
954 std::set<PSBTProprietary> m_proprietary;
955
958
959 bool IsNull() const;
960 void FillSignatureData(SignatureData& sigdata) const;
961 void FromSignatureData(const SignatureData& sigdata);
962 [[nodiscard]] bool Merge(const PSBTOutput& output);
963 uint32_t GetVersion() const { return m_psbt_version; }
964
965 explicit PSBTOutput(uint32_t psbt_version, CAmount amount, const CScript& script)
966 : m_psbt_version(psbt_version),
967 amount(amount),
969 {
971 }
972
973 // Construct a PSBTOutput when the amount and script are expected to be serialized
974 template <typename Stream>
975 explicit PSBTOutput(deserialize_type, Stream& s, uint32_t psbt_version)
976 : m_psbt_version(psbt_version)
977 {
979 Unserialize(s);
980 }
981
982 bool operator==(const PSBTOutput&) const = default;
983
984 template <typename Stream>
985 inline void Serialize(Stream& s) const {
986 // Write the redeem script
987 if (!redeem_script.empty()) {
989 s << redeem_script;
990 }
991
992 // Write the witness script
993 if (!witness_script.empty()) {
995 s << witness_script;
996 }
997
998 // Write any hd keypaths
1000
1001 if (m_psbt_version >= 2) {
1002 // Write amount and spk
1005
1007 s << script;
1008 }
1009
1010 // Write proprietary things
1011 for (const auto& entry : m_proprietary) {
1012 s << entry.key;
1013 s << entry.value;
1014 }
1015
1016 // Write taproot internal key
1017 if (!m_tap_internal_key.IsNull()) {
1020 }
1021
1022 // Write taproot tree
1023 if (!m_tap_tree.empty()) {
1025 std::vector<unsigned char> value;
1026 VectorWriter s_value{value, 0};
1027 for (const auto& [depth, leaf_ver, script] : m_tap_tree) {
1028 s_value << depth;
1029 s_value << leaf_ver;
1030 s_value << script;
1031 }
1032 s << value;
1033 }
1034
1035 // Write taproot bip32 keypaths
1036 for (const auto& [xonly, leaf] : m_tap_bip32_paths) {
1037 const auto& [leaf_hashes, origin] = leaf;
1039 std::vector<unsigned char> value;
1040 VectorWriter s_value{value, 0};
1041 s_value << leaf_hashes;
1042 SerializeKeyOrigin(s_value, origin);
1043 s << value;
1044 }
1045
1046 // Write MuSig2 Participants
1047 for (const auto& [agg_pubkey, part_pubs] : m_musig2_participants) {
1049 std::vector<unsigned char> value;
1050 VectorWriter s_value{value, 0};
1051 for (auto& pk : part_pubs) {
1052 s_value << std::span{pk};
1053 }
1054 s << value;
1055 }
1056
1057 // Write unknown things
1058 for (auto& entry : unknown) {
1059 s << entry.first;
1060 s << entry.second;
1061 }
1062
1063 s << PSBT_SEPARATOR;
1064 }
1065
1066
1067 template <typename Stream>
1068 inline void Unserialize(Stream& s) {
1069 // Used for duplicate key detection
1070 std::set<std::vector<unsigned char>> key_lookup;
1071 // Cache whether PSBTv2 required fields are found
1072 bool found_amount = false;
1073 bool found_script = false;
1074
1075 // Read loop
1076 bool found_sep = false;
1077 while(!s.empty()) {
1078 // Read the key of format "<keylen><keytype><keydata>" after which
1079 // "key" will contain "<keytype><keydata>"
1080 std::vector<unsigned char> key;
1081 s >> key;
1082
1083 // the key is empty if that was actually a separator byte
1084 // This is a special case for key lengths 0 as those are not allowed (except for separator)
1085 if (key.empty()) {
1086 found_sep = true;
1087 break;
1088 }
1089
1090 // Duplicate keys are not permitted
1091 if (!key_lookup.emplace(key).second) {
1092 throw std::ios_base::failure(tfm::format("Duplicate Key, output key \"%s\" already provided", HexStr(key)));
1093 }
1094
1095 // "skey" is used so that "key" is unchanged after reading keytype below
1096 SpanReader skey{key};
1097 // keytype is of the format compact size uint at the beginning of "key"
1098 uint64_t type = ReadCompactSize(skey);
1099
1100 // Do stuff based on keytype "type", i.e., key checks, reading values of the
1101 // format "<valuelen><valuedata>" from the stream "s", and value checks
1102 switch(type) {
1104 {
1105 ExpectedKeySize("Output redeemScript", key, 1);
1106 s >> redeem_script;
1107 break;
1108 }
1110 {
1111 ExpectedKeySize("Output witnessScript", key, 1);
1112 s >> witness_script;
1113 break;
1114 }
1116 {
1118 break;
1119 }
1120 case PSBT_OUT_AMOUNT:
1121 {
1122 ExpectedKeySize("Output Amount", key, 1);
1123 if (m_psbt_version < 2) {
1124 throw std::ios_base::failure("Output amount is not allowed in PSBTv0");
1125 }
1127 found_amount = true;
1128 break;
1129 }
1130 case PSBT_OUT_SCRIPT:
1131 {
1132 ExpectedKeySize("Output Script", key, 1);
1133 if (m_psbt_version < 2) {
1134 throw std::ios_base::failure("Output script is not allowed in PSBTv0");
1135 }
1136 s >> script;
1137 found_script = true;
1138 break;
1139 }
1141 {
1142 ExpectedKeySize("Output Taproot Internal Key", key, 1);
1144 break;
1145 }
1146 case PSBT_OUT_TAP_TREE:
1147 {
1148 ExpectedKeySize("Output Taproot Tree Key", key, 1);
1149 std::vector<unsigned char> tree_v;
1150 s >> tree_v;
1151 SpanReader s_tree{tree_v};
1152 if (s_tree.empty()) {
1153 throw std::ios_base::failure("Output Taproot tree must not be empty");
1154 }
1155 TaprootBuilder builder;
1156 while (!s_tree.empty()) {
1157 uint8_t depth;
1158 uint8_t leaf_ver;
1159 std::vector<unsigned char> script;
1160 s_tree >> depth;
1161 s_tree >> leaf_ver;
1162 s_tree >> script;
1163 if (depth > TAPROOT_CONTROL_MAX_NODE_COUNT) {
1164 throw std::ios_base::failure("Output Taproot tree has as leaf greater than Taproot maximum depth");
1165 }
1166 if ((leaf_ver & ~TAPROOT_LEAF_MASK) != 0) {
1167 throw std::ios_base::failure("Output Taproot tree has a leaf with an invalid leaf version");
1168 }
1169 m_tap_tree.emplace_back(depth, leaf_ver, script);
1170 builder.Add((int)depth, script, (int)leaf_ver, /*track=*/true);
1171 }
1172 if (!builder.IsComplete()) {
1173 throw std::ios_base::failure("Output Taproot tree is malformed");
1174 }
1175 break;
1176 }
1178 {
1179 ExpectedKeySize("Output Taproot BIP32 Keypath", key, 33);
1180 XOnlyPubKey xonly(uint256(std::span<uint8_t>(key).last(32)));
1181 std::set<uint256> leaf_hashes;
1182 uint64_t value_len = ReadCompactSize(s);
1183 size_t before_hashes = s.size();
1184 s >> leaf_hashes;
1185 size_t after_hashes = s.size();
1186 size_t hashes_len = before_hashes - after_hashes;
1187 if (hashes_len > value_len) {
1188 throw std::ios_base::failure("Output Taproot BIP32 keypath has an invalid length");
1189 }
1190 size_t origin_len = value_len - hashes_len;
1191 m_tap_bip32_paths.emplace(xonly, std::make_pair(leaf_hashes, DeserializeKeyOrigin(s, origin_len)));
1192 break;
1193 }
1195 {
1196 ExpectedKeySize("Output MuSig2 Participants Pubkeys", key, CPubKey::COMPRESSED_SIZE + 1);
1197 DeserializeMuSig2ParticipantPubkeys(s, skey, m_musig2_participants, std::string{"Output"});
1198 break;
1199 }
1201 {
1202 PSBTProprietary this_prop;
1203 skey >> this_prop.identifier;
1204 this_prop.subtype = ReadCompactSize(skey);
1205 this_prop.key = key;
1206
1207 s >> this_prop.value;
1208 m_proprietary.insert(this_prop);
1209 break;
1210 }
1211 // Unknown stuff
1212 default: {
1213 // Read in the value
1214 std::vector<unsigned char> val_bytes;
1215 s >> val_bytes;
1216 unknown.emplace(std::move(key), std::move(val_bytes));
1217 break;
1218 }
1219 }
1220 }
1221
1222 if (!found_sep) {
1223 throw std::ios_base::failure("Separator is missing at the end of an output map");
1224 }
1225
1226 // Make sure required PSBTv2 fields are present
1227 if (m_psbt_version >= 2) {
1228 if (!found_amount) {
1229 throw std::ios_base::failure("Output amount is required in PSBTv2");
1230 }
1231 if (!found_script) {
1232 throw std::ios_base::failure("Output script is required in PSBTv2");
1233 }
1234 }
1235 }
1236};
1237
1240{
1241private:
1242 std::optional<uint32_t> m_version;
1243
1244public:
1245 // We use a vector of CExtPubKey in the event that there happens to be the same KeyOriginInfos for different CExtPubKeys
1246 // Note that this map swaps the key and values from the serialization
1247 std::map<KeyOriginInfo, std::set<CExtPubKey>> m_xpubs;
1248 std::optional<std::bitset<8>> m_tx_modifiable;
1249 std::vector<PSBTInput> inputs;
1250 std::vector<PSBTOutput> outputs;
1251 std::map<std::vector<unsigned char>, std::vector<unsigned char>> unknown;
1252 std::set<PSBTProprietary> m_proprietary;
1253
1254 uint32_t tx_version;
1255 std::optional<uint32_t> fallback_locktime;
1256
1257 bool IsNull() const;
1258 uint32_t GetVersion() const;
1259
1262 [[nodiscard]] bool Merge(const PartiallySignedTransaction& psbt);
1263 bool AddInput(const PSBTInput& psbtin);
1264 bool AddOutput(const PSBTOutput& psbtout);
1265 std::optional<uint32_t> ComputeTimeLock() const;
1266 std::optional<CMutableTransaction> GetUnsignedTx() const;
1267 std::optional<Txid> GetUniqueID() const;
1268 explicit PartiallySignedTransaction(const CMutableTransaction& tx, uint32_t version = 2);
1269
1270 template <typename Stream>
1271 inline void Serialize(Stream& s) const {
1272
1273 // magic bytes
1275
1276 if (GetVersion() < 2) {
1277 // unsigned tx flag
1279
1280 // Write serialized tx to a stream
1282 }
1283
1284 // Write xpubs
1285 for (const auto& xpub_pair : m_xpubs) {
1286 for (const auto& xpub : xpub_pair.second) {
1287 unsigned char ser_xpub[BIP32_EXTKEY_WITH_VERSION_SIZE];
1288 xpub.EncodeWithVersion(ser_xpub);
1289 // Note that the serialization swaps the key and value
1290 // The xpub is the key (for uniqueness) while the path is the value
1292 SerializeHDKeypath(s, xpub_pair.first);
1293 }
1294 }
1295
1296 if (GetVersion() >= 2) {
1297 // Write PSBTv2 tx version, locktime, counts, etc.
1300 if (fallback_locktime != std::nullopt) {
1303 }
1304
1309
1310 if (m_tx_modifiable != std::nullopt) {
1312 SerializeToVector(s, static_cast<uint8_t>(m_tx_modifiable->to_ulong()));
1313 }
1314 }
1315
1316 // PSBT version
1317 if (GetVersion() > 0) {
1320 }
1321
1322 // Write proprietary things
1323 for (const auto& entry : m_proprietary) {
1324 s << entry.key;
1325 s << entry.value;
1326 }
1327
1328 // Write the unknown things
1329 for (auto& entry : unknown) {
1330 s << entry.first;
1331 s << entry.second;
1332 }
1333
1334 // Separator
1335 s << PSBT_SEPARATOR;
1336
1337 // Write inputs
1338 for (const PSBTInput& input : inputs) {
1339 s << input;
1340 }
1341 // Write outputs
1342 for (const PSBTOutput& output : outputs) {
1343 s << output;
1344 }
1345 }
1346
1347
1348 template <typename Stream>
1349 inline void Unserialize(Stream& s) {
1350 // Read the magic bytes
1351 uint8_t magic[5];
1352 s >> magic;
1353 if (!std::equal(magic, magic + 5, PSBT_MAGIC_BYTES)) {
1354 throw std::ios_base::failure("Invalid PSBT magic bytes");
1355 }
1356
1357 // Used for duplicate key detection
1358 std::set<std::vector<unsigned char>> key_lookup;
1359
1360 // Track the global xpubs we have already seen. Just for sanity checking
1361 std::set<CExtPubKey> global_xpubs;
1362
1363 // Read global data
1364 bool found_sep = false;
1365 std::optional<CMutableTransaction> tx;
1366 uint64_t input_count = 0;
1367 uint64_t output_count = 0;
1368 bool found_input_count = false;
1369 bool found_output_count = false;
1370 bool found_tx_version = false;
1371 bool found_fallback_locktime = false;
1372 while(!s.empty()) {
1373 // Read the key of format "<keylen><keytype><keydata>" after which
1374 // "key" will contain "<keytype><keydata>"
1375 std::vector<unsigned char> key;
1376 s >> key;
1377
1378 // the key is empty if that was actually a separator byte
1379 // This is a special case for key lengths 0 as those are not allowed (except for separator)
1380 if (key.empty()) {
1381 found_sep = true;
1382 break;
1383 }
1384
1385 // Duplicate keys are not permitted
1386 if (!key_lookup.emplace(key).second) {
1387 throw std::ios_base::failure(tfm::format("Duplicate Key, global key \"%s\" already provided", HexStr(key)));
1388 }
1389
1390 // "skey" is used so that "key" is unchanged after reading keytype below
1391 SpanReader skey{key};
1392 // keytype is of the format compact size uint at the beginning of "key"
1393 uint64_t type = ReadCompactSize(skey);
1394
1395 // Do stuff based on keytype "type", i.e., key checks, reading values of the
1396 // format "<valuelen><valuedata>" from the stream "s", and value checks
1397 switch(type) {
1399 {
1400 ExpectedKeySize("Global Unsigned TX", key, 1);
1401 // Set the stream to serialize with non-witness since this should always be non-witness
1402 tx.emplace();
1404 // Make sure that all scriptSigs and scriptWitnesses are empty
1405 for (const CTxIn& txin : tx->vin) {
1406 if (!txin.scriptSig.empty() || !txin.scriptWitness.IsNull()) {
1407 throw std::ios_base::failure("Unsigned tx does not have empty scriptSigs and scriptWitnesses.");
1408 }
1409 }
1410 tx_version = tx->version;
1411 fallback_locktime = tx->nLockTime;
1412 // Set the input and output counts
1413 input_count = tx->vin.size();
1414 output_count = tx->vout.size();
1415 break;
1416 }
1418 {
1419 ExpectedKeySize("Global Transaction Version", key, 1);
1421 found_tx_version = true;
1422 break;
1423 }
1425 {
1426 ExpectedKeySize("Global Fallback Locktime", key, 1);
1427 fallback_locktime.emplace();
1429 found_fallback_locktime = true;
1430 break;
1431 }
1433 {
1434 ExpectedKeySize("Global Input Count", key, 1);
1435 CompactSizeReader reader(input_count);
1436 UnserializeFromVector(s, reader);
1437 found_input_count = true;
1438 break;
1439 }
1441 {
1442 ExpectedKeySize("Global Output Count", key, 1);
1443 CompactSizeReader reader(output_count);
1444 UnserializeFromVector(s, reader);
1445 found_output_count = true;
1446 break;
1447 }
1449 {
1450 ExpectedKeySize("Global TX Modifiable Flags", key, 1);
1451 uint8_t tx_mod;
1452 UnserializeFromVector(s, tx_mod);
1453 m_tx_modifiable.emplace(tx_mod);
1454 break;
1455 }
1456 case PSBT_GLOBAL_XPUB:
1457 {
1458 ExpectedKeySize("Global XPUB", key, BIP32_EXTKEY_WITH_VERSION_SIZE + 1);
1459 // Read in the xpub from key
1460 CExtPubKey xpub;
1461 xpub.DecodeWithVersion(&key.data()[1]);
1462 if (!xpub.pubkey.IsFullyValid()) {
1463 throw std::ios_base::failure("Invalid pubkey");
1464 }
1465 global_xpubs.insert(xpub);
1466 // Read in the keypath from stream
1467 KeyOriginInfo keypath;
1468 DeserializeHDKeypath(s, keypath);
1469
1470 // Note that we store these swapped to make searches faster.
1471 // Serialization uses xpub -> keypath to enqure key uniqueness
1472 if (!m_xpubs.contains(keypath)) {
1473 // Make a new set to put the xpub in
1474 m_xpubs[keypath] = {xpub};
1475 } else {
1476 // Insert xpub into existing set
1477 m_xpubs[keypath].insert(xpub);
1478 }
1479 break;
1480 }
1482 {
1483 ExpectedKeySize("Global PSBT Version", key, 1);
1484 uint32_t v;
1486 m_version = v;
1488 throw std::ios_base::failure("Unsupported version number");
1489 }
1490 break;
1491 }
1493 {
1494 PSBTProprietary this_prop;
1495 skey >> this_prop.identifier;
1496 this_prop.subtype = ReadCompactSize(skey);
1497 this_prop.key = key;
1498
1499 s >> this_prop.value;
1500 m_proprietary.insert(this_prop);
1501 break;
1502 }
1503 // Unknown stuff
1504 default: {
1505 // Read in the value
1506 std::vector<unsigned char> val_bytes;
1507 s >> val_bytes;
1508 unknown.emplace(std::move(key), std::move(val_bytes));
1509 }
1510 }
1511 }
1512
1513 if (!found_sep) {
1514 throw std::ios_base::failure("Separator is missing at the end of the global map");
1515 }
1516
1517 const uint32_t psbt_ver = GetVersion();
1518
1519 // Check PSBT version constraints
1520 if (psbt_ver == 0) {
1521 // Make sure that we got an unsigned tx for PSBTv0
1522 if (!tx) {
1523 throw std::ios_base::failure("No unsigned transaction was provided");
1524 }
1525 // Make sure no PSBTv2 fields are present
1526 if (found_tx_version) {
1527 throw std::ios_base::failure("PSBT_GLOBAL_TX_VERSION is not allowed in PSBTv0");
1528 }
1529 if (found_fallback_locktime) {
1530 throw std::ios_base::failure("PSBT_GLOBAL_FALLBACK_LOCKTIME is not allowed in PSBTv0");
1531 }
1532 if (found_input_count) {
1533 throw std::ios_base::failure("PSBT_GLOBAL_INPUT_COUNT is not allowed in PSBTv0");
1534 }
1535 if (found_output_count) {
1536 throw std::ios_base::failure("PSBT_GLOBAL_OUTPUT_COUNT is not allowed in PSBTv0");
1537 }
1538 if (m_tx_modifiable != std::nullopt) {
1539 throw std::ios_base::failure("PSBT_GLOBAL_TX_MODIFIABLE is not allowed in PSBTv0");
1540 }
1541 }
1542 // Disallow v1
1543 if (psbt_ver == 1) {
1544 throw std::ios_base::failure("There is no PSBT version 1");
1545 }
1546 if (psbt_ver == 2) {
1547 // Tx version, input, and output counts are required
1548 if (!found_tx_version) {
1549 throw std::ios_base::failure("PSBT_GLOBAL_TX_VERSION is required in PSBTv2");
1550 }
1551 if (!found_input_count) {
1552 throw std::ios_base::failure("PSBT_GLOBAL_INPUT_COUNT is required in PSBTv2");
1553 }
1554 if (!found_output_count) {
1555 throw std::ios_base::failure("PSBT_GLOBAL_OUTPUT_COUNT is required in PSBTv2");
1556 }
1557 // Unsigned tx is disallowed
1558 if (tx) {
1559 throw std::ios_base::failure("PSBT_GLOBAL_UNSIGNED_TX is not allowed in PSBTv2");
1560 }
1561 }
1562 if (psbt_ver > 2) {
1563 throw std::ios_base::failure("Unknown PSBT version");
1564 }
1565
1566 // Read input data
1567 unsigned int i = 0;
1568 while (!s.empty() && i < input_count) {
1569 if (psbt_ver < 2) {
1570 inputs.emplace_back(psbt_ver, tx->vin[i].prevout.hash, tx->vin[i].prevout.n, tx->vin[i].nSequence);
1571 s >> inputs.back();
1572 } else {
1573 inputs.emplace_back(deserialize, s, psbt_ver);
1574 }
1575
1576 // Make sure the non-witness utxo matches the outpoint
1577 const PSBTInput& input = inputs.back();
1578 if (input.non_witness_utxo) {
1579 if (psbt_ver < 2) {
1580 if (input.non_witness_utxo->GetHash() != tx->vin[i].prevout.hash) {
1581 throw std::ios_base::failure("Non-witness UTXO does not match outpoint hash");
1582 }
1583 if (tx->vin[i].prevout.n >= input.non_witness_utxo->vout.size()) {
1584 throw std::ios_base::failure("Input specifies output index that does not exist");
1585 }
1586 } else {
1587 if (input.non_witness_utxo->GetHash() != input.prev_txid) {
1588 throw std::ios_base::failure("Non-witness UTXO does not match outpoint hash");
1589 }
1590 if (input.prev_out >= input.non_witness_utxo->vout.size()) {
1591 throw std::ios_base::failure("Input specifies output index that does not exist");
1592 }
1593 }
1594 }
1595 ++i;
1596 }
1597 // Make sure that the number of inputs matches the number of inputs in the transaction
1598 if (inputs.size() != input_count) {
1599 throw std::ios_base::failure("Inputs provided does not match the number of inputs in transaction.");
1600 }
1601
1602 // Read output data
1603 i = 0;
1604 while (!s.empty() && i < output_count) {
1605 if (psbt_ver < 2) {
1606 outputs.emplace_back(psbt_ver, tx->vout[i].nValue, tx->vout[i].scriptPubKey);
1607 s >> outputs.back();
1608 } else {
1609 outputs.emplace_back(deserialize, s, psbt_ver);
1610 }
1611 ++i;
1612 }
1613 // Make sure that the number of outputs matches the number of outputs in the transaction
1614 if (outputs.size() != output_count) {
1615 throw std::ios_base::failure("Outputs provided does not match the number of outputs in transaction.");
1616 }
1617 }
1618
1619 template <typename Stream>
1621 Unserialize(s);
1622 }
1623};
1624
1625enum class PSBTRole {
1626 CREATOR,
1627 UPDATER,
1628 SIGNER,
1629 FINALIZER,
1630 EXTRACTOR
1631};
1632
1633std::string PSBTRoleName(PSBTRole role);
1634
1636std::optional<PrecomputedTransactionData> PrecomputePSBTData(const PartiallySignedTransaction& psbt);
1637
1639bool PSBTInputSigned(const PSBTInput& input);
1640
1642bool PSBTInputSignedAndVerified(const PartiallySignedTransaction& psbt, unsigned int input_index, const PrecomputedTransactionData* txdata);
1643
1649[[nodiscard]] PSBTError SignPSBTInput(const SigningProvider& provider, PartiallySignedTransaction& psbt, int index, const PrecomputedTransactionData* txdata, const common::PSBTFillOptions& options, SignatureData* out_sigdata = nullptr);
1650
1653
1656
1662
1670
1679
1686[[nodiscard]] std::optional<PartiallySignedTransaction> CombinePSBTs(const std::vector<PartiallySignedTransaction>& psbtxs);
1687
1689[[nodiscard]] util::Result<PartiallySignedTransaction> DecodeBase64PSBT(const std::string& base64_tx);
1691[[nodiscard]] util::Result<PartiallySignedTransaction> DecodeRawPSBT(std::span<const std::byte> tx_data);
1692
1693#endif // BITCOIN_PSBT_H
int64_t CAmount
Amount in satoshis (Can be negative)
Definition: amount.h:12
ArgsManager & args
Definition: bitcoind.cpp:280
static const size_t OUTPUT_SIZE
Definition: hash.h:53
static const size_t OUTPUT_SIZE
Definition: hash.h:28
An outpoint - a combination of a transaction hash and an index n into its vout.
Definition: transaction.h:29
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:160
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:320
void Set(const T pbegin, const T pend)
Initialize a public key using begin/end iterators to byte data.
Definition: pubkey.h:89
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:406
An input of a transaction.
Definition: transaction.h:62
CScript scriptSig
Definition: transaction.h:65
CScriptWitness scriptWitness
Only serialized through CTransaction.
Definition: transaction.h:67
An output of a transaction.
Definition: transaction.h:140
bool IsNull() const
Definition: transaction.h:160
A structure for PSBTs which contain per-input information.
Definition: psbt.h:281
std::vector< unsigned char > m_tap_key_sig
Definition: psbt.h:306
std::map< CPubKey, KeyOriginInfo > hd_keypaths
Definition: psbt.h:292
uint32_t m_psbt_version
Definition: psbt.h:283
std::map< uint256, std::vector< unsigned char > > hash256_preimages
Definition: psbt.h:297
bool Merge(const PSBTInput &input)
Definition: psbt.cpp:427
CScriptWitness final_script_witness
Definition: psbt.h:291
std::optional< uint32_t > sequence
Definition: psbt.h:301
std::map< std::pair< CPubKey, uint256 >, std::map< CPubKey, std::vector< uint8_t > > > m_musig2_pubnonces
Definition: psbt.h:316
bool HasSignatures() const
Definition: psbt.cpp:467
bool GetUTXO(CTxOut &utxo) const
Retrieves the UTXO for this input.
Definition: psbt.cpp:269
std::map< std::pair< std::vector< unsigned char >, int >, std::set< std::vector< unsigned char >, ShortestVectorFirstComparator > > m_tap_scripts
Definition: psbt.h:308
CTransactionRef non_witness_utxo
Definition: psbt.h:286
Txid prev_txid
Definition: psbt.h:299
std::map< CKeyID, SigPair > partial_sigs
Definition: psbt.h:293
std::optional< int > sighash_type
Definition: psbt.h:322
std::map< std::pair< XOnlyPubKey, uint256 >, std::vector< unsigned char > > m_tap_script_sigs
Definition: psbt.h:307
void Serialize(Stream &s) const
Definition: psbt.h:360
std::optional< uint32_t > time_locktime
Definition: psbt.h:302
uint256 m_tap_merkle_root
Definition: psbt.h:311
std::map< uint256, std::vector< unsigned char > > sha256_preimages
Definition: psbt.h:295
void FillSignatureData(SignatureData &sigdata) const
Definition: psbt.cpp:297
std::map< std::pair< CPubKey, uint256 >, std::map< CPubKey, uint256 > > m_musig2_partial_sigs
Definition: psbt.h:318
COutPoint GetOutPoint() const
Definition: psbt.cpp:287
std::map< uint160, std::vector< unsigned char > > hash160_preimages
Definition: psbt.h:296
bool operator==(const PSBTInput &) const =default
bool IsNull() const
Definition: psbt.cpp:292
uint32_t prev_out
Definition: psbt.h:300
PSBTInput(uint32_t psbt_version, const Txid &prev_txid, uint32_t prev_out, std::optional< uint32_t > sequence=std::nullopt)
Definition: psbt.h:339
void Unserialize(Stream &s)
Definition: psbt.h:559
std::map< CPubKey, std::vector< CPubKey > > m_musig2_participants
Definition: psbt.h:314
std::set< PSBTProprietary > m_proprietary
Definition: psbt.h:321
CScript redeem_script
Definition: psbt.h:288
CScript final_script_sig
Definition: psbt.h:290
PSBTInput(deserialize_type, Stream &s, uint32_t psbt_version)
Definition: psbt.h:350
void FromSignatureData(const SignatureData &sigdata)
Definition: psbt.cpp:361
uint32_t GetVersion() const
Definition: psbt.h:328
XOnlyPubKey m_tap_internal_key
Definition: psbt.h:310
std::optional< uint32_t > height_locktime
Definition: psbt.h:303
std::map< XOnlyPubKey, std::pair< std::set< uint256 >, KeyOriginInfo > > m_tap_bip32_paths
Definition: psbt.h:309
std::map< std::vector< unsigned char >, std::vector< unsigned char > > unknown
Definition: psbt.h:320
std::map< uint160, std::vector< unsigned char > > ripemd160_preimages
Definition: psbt.h:294
CTxOut witness_utxo
Definition: psbt.h:287
CScript witness_script
Definition: psbt.h:289
A structure for PSBTs which contains per output information.
Definition: psbt.h:939
std::map< CPubKey, std::vector< CPubKey > > m_musig2_participants
Definition: psbt.h:951
XOnlyPubKey m_tap_internal_key
Definition: psbt.h:948
std::map< XOnlyPubKey, std::pair< std::set< uint256 >, KeyOriginInfo > > m_tap_bip32_paths
Definition: psbt.h:950
bool operator==(const PSBTOutput &) const =default
CScript witness_script
Definition: psbt.h:945
bool IsNull() const
Definition: psbt.cpp:531
std::set< PSBTProprietary > m_proprietary
Definition: psbt.h:954
PSBTOutput(deserialize_type, Stream &s, uint32_t psbt_version)
Definition: psbt.h:975
CAmount amount
Definition: psbt.h:956
CScript redeem_script
Definition: psbt.h:944
void Serialize(Stream &s) const
Definition: psbt.h:985
CScript script
Definition: psbt.h:957
uint32_t GetVersion() const
Definition: psbt.h:963
uint32_t m_psbt_version
Definition: psbt.h:941
bool Merge(const PSBTOutput &output)
Definition: psbt.cpp:536
std::map< CPubKey, KeyOriginInfo > hd_keypaths
Definition: psbt.h:946
std::vector< std::tuple< uint8_t, uint8_t, std::vector< unsigned char > > > m_tap_tree
Definition: psbt.h:949
void Unserialize(Stream &s)
Definition: psbt.h:1068
std::map< std::vector< unsigned char >, std::vector< unsigned char > > unknown
Definition: psbt.h:953
void FillSignatureData(SignatureData &sigdata) const
Definition: psbt.cpp:477
PSBTOutput(uint32_t psbt_version, CAmount amount, const CScript &script)
Definition: psbt.h:965
void FromSignatureData(const SignatureData &sigdata)
Definition: psbt.cpp:508
A version of CTransaction with the PSBT format.
Definition: psbt.h:1240
std::optional< std::bitset< 8 > > m_tx_modifiable
Definition: psbt.h:1248
uint32_t GetVersion() const
Definition: psbt.cpp:887
bool Merge(const PartiallySignedTransaction &psbt)
Merge psbt into this.
Definition: psbt.cpp:39
std::map< KeyOriginInfo, std::set< CExtPubKey > > m_xpubs
Definition: psbt.h:1247
std::optional< uint32_t > m_version
Definition: psbt.h:1242
bool IsNull() const
Definition: psbt.cpp:34
std::optional< Txid > GetUniqueID() const
Definition: psbt.cpp:148
std::map< std::vector< unsigned char >, std::vector< unsigned char > > unknown
Definition: psbt.h:1251
std::vector< PSBTInput > inputs
Definition: psbt.h:1249
std::optional< CMutableTransaction > GetUnsignedTx() const
Definition: psbt.cpp:122
std::optional< uint32_t > ComputeTimeLock() const
Definition: psbt.cpp:88
std::vector< PSBTOutput > outputs
Definition: psbt.h:1250
std::set< PSBTProprietary > m_proprietary
Definition: psbt.h:1252
void Serialize(Stream &s) const
Definition: psbt.h:1271
bool AddOutput(const PSBTOutput &psbtout)
Definition: psbt.cpp:246
PartiallySignedTransaction(deserialize_type, Stream &s)
Definition: psbt.h:1620
std::optional< uint32_t > fallback_locktime
Definition: psbt.h:1255
void Unserialize(Stream &s)
Definition: psbt.h:1349
PartiallySignedTransaction(const CMutableTransaction &tx, uint32_t version=2)
Definition: psbt.cpp:18
bool AddInput(const PSBTInput &psbtin)
Definition: psbt.cpp:163
An interface to be implemented by keystores that support signing.
uint64_t size() const
Definition: serialize.h:1092
Minimal stream for reading from an existing byte array by std::span.
Definition: streams.h:83
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, std::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:250
constexpr bool IsNull() const
Definition: uint256.h:49
constexpr void SetNull()
Definition: uint256.h:56
bool empty() const
Definition: prevector.h:251
160-bit opaque blob.
Definition: uint256.h:184
256-bit opaque blob.
Definition: uint256.h:196
is a home for simple enum and struct type definitions that can be used internally by functions in the...
std::string HexStr(const std::span< const uint8_t > s)
Convert a span of bytes to a lower-case hexadecimal string.
Definition: hex_base.cpp:30
bool CheckSignatureEncoding(const std::vector< unsigned char > &vchSig, script_verify_flags flags, ScriptError *serror)
static constexpr uint8_t TAPROOT_LEAF_MASK
Definition: interpreter.h:242
static constexpr size_t TAPROOT_CONTROL_MAX_NODE_COUNT
Definition: interpreter.h:246
constexpr size_t MUSIG2_PUBNONCE_SIZE
Definition: musig.h:18
PSBTError
Definition: types.h:19
Definition: messages.h:21
TransactionError
Definition: types.h:19
void format(std::ostream &out, FormatStringCheck< sizeof...(Args)> fmt, const Args &... args)
Format list of arguments to the stream according to given format string.
Definition: tinyformat.h:1079
#define X(name)
Definition: net.cpp:620
static constexpr TransactionSerParams TX_NO_WITNESS
Definition: transaction.h:181
static constexpr TransactionSerParams TX_WITH_WITNESS
Definition: transaction.h:180
std::shared_ptr< const CTransaction > CTransactionRef
Definition: transaction.h:403
static constexpr uint8_t PSBT_OUT_AMOUNT
Definition: psbt.h:79
PSBTError SignPSBTInput(const SigningProvider &provider, PartiallySignedTransaction &psbt, int index, const PrecomputedTransactionData *txdata, const common::PSBTFillOptions &options, SignatureData *out_sigdata=nullptr)
Signs a PSBTInput, verifying that all provided data matches what is being signed.
Definition: psbt.cpp:647
void SerializeToVector(Stream &s, const X &... args)
Definition: psbt.h:117
static constexpr uint8_t PSBT_IN_REQUIRED_HEIGHT_LOCKTIME
Definition: psbt.h:63
static constexpr uint8_t PSBT_IN_RIPEMD160
Definition: psbt.h:55
void UpdatePSBTOutput(const SigningProvider &provider, PartiallySignedTransaction &psbt, int index)
Updates a PSBTOutput with information from provider.
Definition: psbt.cpp:602
static constexpr uint8_t PSBT_IN_HASH256
Definition: psbt.h:58
static constexpr uint8_t PSBT_IN_REQUIRED_TIME_LOCKTIME
Definition: psbt.h:62
static constexpr uint8_t PSBT_GLOBAL_UNSIGNED_TX
Definition: psbt.h:35
static constexpr uint8_t PSBT_IN_NON_WITNESS_UTXO
Definition: psbt.h:46
static constexpr uint8_t PSBT_IN_TAP_KEY_SIG
Definition: psbt.h:64
void UnserializeFromVector(Stream &s, X &&... args)
Definition: psbt.h:127
static constexpr uint8_t PSBT_IN_SCRIPTSIG
Definition: psbt.h:53
static constexpr uint8_t PSBT_IN_WITNESSSCRIPT
Definition: psbt.h:51
static constexpr uint8_t PSBT_IN_OUTPUT_INDEX
Definition: psbt.h:60
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:557
std::string PSBTRoleName(PSBTRole role)
Definition: psbt.cpp:853
util::Result< PartiallySignedTransaction > DecodeBase64PSBT(const std::string &base64_tx)
Decode a base64ed PSBT into a PartiallySignedTransaction.
Definition: psbt.cpp:864
static constexpr uint8_t PSBT_OUT_REDEEMSCRIPT
Definition: psbt.h:76
static constexpr uint8_t PSBT_GLOBAL_VERSION
Definition: psbt.h:42
static constexpr uint8_t PSBT_GLOBAL_TX_VERSION
Definition: psbt.h:37
static constexpr uint8_t PSBT_IN_TAP_LEAF_SCRIPT
Definition: psbt.h:66
static constexpr uint8_t PSBT_OUT_PROPRIETARY
Definition: psbt.h:85
static constexpr uint8_t PSBT_MAGIC_BYTES[5]
Definition: psbt.h:32
std::optional< PartiallySignedTransaction > CombinePSBTs(const std::vector< PartiallySignedTransaction > &psbtxs)
Combines PSBTs with the same underlying transaction, resulting in a single PSBT with all partial sign...
Definition: psbt.cpp:840
static constexpr uint32_t PSBT_HIGHEST_VERSION
Definition: psbt.h:96
static constexpr uint8_t PSBT_SEPARATOR
Definition: psbt.h:89
static constexpr uint8_t PSBT_IN_BIP32_DERIVATION
Definition: psbt.h:52
void DeserializeMuSig2ParticipantPubkeys(Stream &s, SpanReader &skey, std::map< CPubKey, std::vector< CPubKey > > &out, std::string context)
Definition: psbt.h:218
static constexpr uint8_t PSBT_IN_SCRIPTWITNESS
Definition: psbt.h:54
static constexpr uint8_t PSBT_OUT_TAP_TREE
Definition: psbt.h:82
static constexpr uint8_t PSBT_IN_PREVIOUS_TXID
Definition: psbt.h:59
static constexpr uint8_t PSBT_OUT_BIP32_DERIVATION
Definition: psbt.h:78
PSBTRole
Definition: psbt.h:1625
static constexpr uint8_t PSBT_GLOBAL_PROPRIETARY
Definition: psbt.h:43
void RemoveUnnecessaryTransactions(PartiallySignedTransaction &psbtx)
Reduces the size of the PSBT by dropping unnecessary non_witness_utxos (i.e.
Definition: psbt.cpp:763
std::optional< PrecomputedTransactionData > PrecomputePSBTData(const PartiallySignedTransaction &psbt)
Compute a PrecomputedTransactionData object from a psbt.
Definition: psbt.cpp:626
static constexpr uint8_t PSBT_IN_PROPRIETARY
Definition: psbt.h:73
static constexpr uint8_t PSBT_GLOBAL_TX_MODIFIABLE
Definition: psbt.h:41
static constexpr uint8_t PSBT_IN_SEQUENCE
Definition: psbt.h:61
KeyOriginInfo DeserializeKeyOrigin(Stream &s, uint64_t length)
Definition: psbt.h:140
void DeserializeMuSig2ParticipantDataIdentifier(Stream &skey, CPubKey &agg_pub, CPubKey &part_pub, uint256 &leaf_hash)
Definition: psbt.h:250
static constexpr uint8_t PSBT_IN_TAP_SCRIPT_SIG
Definition: psbt.h:65
static constexpr uint8_t PSBT_IN_MUSIG2_PUB_NONCE
Definition: psbt.h:71
void SerializeHDKeypaths(Stream &s, const std::map< CPubKey, KeyOriginInfo > &hd_keypaths, CompactSizeWriter type)
Definition: psbt.h:205
static void ExpectedKeySize(const std::string &key_name, const std::vector< unsigned char > &key, uint64_t expected_size)
Definition: psbt.h:273
static constexpr uint8_t PSBT_IN_TAP_BIP32_DERIVATION
Definition: psbt.h:67
static constexpr uint8_t PSBT_IN_HASH160
Definition: psbt.h:57
static constexpr uint8_t PSBT_IN_REDEEMSCRIPT
Definition: psbt.h:50
static constexpr uint8_t PSBT_OUT_WITNESSSCRIPT
Definition: psbt.h:77
static constexpr uint8_t PSBT_GLOBAL_XPUB
Definition: psbt.h:36
static constexpr uint8_t PSBT_OUT_MUSIG2_PARTICIPANT_PUBKEYS
Definition: psbt.h:84
static constexpr uint8_t PSBT_GLOBAL_OUTPUT_COUNT
Definition: psbt.h:40
static constexpr uint8_t PSBT_OUT_TAP_BIP32_DERIVATION
Definition: psbt.h:83
static constexpr uint8_t PSBT_IN_PARTIAL_SIG
Definition: psbt.h:48
static constexpr uint8_t PSBT_GLOBAL_FALLBACK_LOCKTIME
Definition: psbt.h:38
static constexpr uint8_t PSBT_IN_TAP_INTERNAL_KEY
Definition: psbt.h:68
size_t CountPSBTUnsignedInputs(const PartiallySignedTransaction &psbt)
Counts the unsigned inputs of a PSBT.
Definition: psbt.cpp:591
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:820
static constexpr uint8_t PSBT_OUT_TAP_INTERNAL_KEY
Definition: psbt.h:81
static constexpr uint8_t PSBT_IN_TAP_MERKLE_ROOT
Definition: psbt.h:69
void SerializeKeyOrigin(Stream &s, KeyOriginInfo hd_keypath)
Definition: psbt.h:187
void DeserializeHDKeypaths(Stream &s, const std::vector< unsigned char > &key, std::map< CPubKey, KeyOriginInfo > &hd_keypaths)
Definition: psbt.h:166
static constexpr uint8_t PSBT_IN_SIGHASH
Definition: psbt.h:49
bool PSBTInputSigned(const PSBTInput &input)
Checks whether a PSBTInput is already signed by checking for non-null finalized fields.
Definition: psbt.cpp:552
static constexpr uint8_t PSBT_IN_MUSIG2_PARTICIPANT_PUBKEYS
Definition: psbt.h:70
void SerializeHDKeypath(Stream &s, KeyOriginInfo hd_keypath)
Definition: psbt.h:197
void DeserializeHDKeypath(Stream &s, KeyOriginInfo &hd_keypath)
Definition: psbt.h:159
bool FinalizePSBT(PartiallySignedTransaction &psbtx)
Finalizes a PSBT if possible, combining partial signatures.
Definition: psbt.cpp:800
static constexpr uint8_t PSBT_OUT_SCRIPT
Definition: psbt.h:80
util::Result< PartiallySignedTransaction > DecodeRawPSBT(std::span< const std::byte > tx_data)
Decode a raw (binary blob) PSBT into a PartiallySignedTransaction.
Definition: psbt.cpp:873
static constexpr uint8_t PSBT_GLOBAL_INPUT_COUNT
Definition: psbt.h:39
const std::streamsize MAX_FILE_SIZE_PSBT
Definition: psbt.h:93
static constexpr uint8_t PSBT_IN_WITNESS_UTXO
Definition: psbt.h:47
static constexpr uint8_t PSBT_IN_MUSIG2_PARTIAL_SIG
Definition: psbt.h:72
static constexpr uint8_t PSBT_IN_SHA256
Definition: psbt.h:56
const unsigned int BIP32_EXTKEY_WITH_VERSION_SIZE
Definition: pubkey.h:20
static const unsigned int LOCKTIME_THRESHOLD
Definition: script.h:48
std::vector< unsigned char > ToByteVector(const T &in)
Definition: script.h:68
void SerializeMany(Stream &s, const Args &... args)
Support for (un)serializing many things at once.
Definition: serialize.h:1000
constexpr deserialize_type deserialize
Definition: serialize.h:51
void UnserializeMany(Stream &s, Args &&... args)
Definition: serialize.h:1006
void WriteCompactSize(SizeComputer &os, uint64_t nSize)
Definition: serialize.h:1104
uint64_t ReadCompactSize(Stream &is, bool range_check=true)
Decode a CompactSize-encoded variable-length integer.
Definition: serialize.h:332
std::pair< CPubKey, std::vector< unsigned char > > SigPair
Definition: sign.h:82
void DecodeWithVersion(const unsigned char code[BIP32_EXTKEY_WITH_VERSION_SIZE])
Definition: pubkey.cpp:409
CPubKey pubkey
Definition: pubkey.h:342
A mutable version of CTransaction.
Definition: transaction.h:358
std::vector< std::vector< unsigned char > > stack
Definition: script.h:581
bool IsNull() const
Definition: script.h:586
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 PSBT proprietary types.
Definition: psbt.h:100
std::vector< unsigned char > value
Definition: psbt.h:104
bool operator<(const PSBTProprietary &b) const
Definition: psbt.h:106
uint64_t subtype
Definition: psbt.h:101
std::vector< unsigned char > identifier
Definition: psbt.h:102
std::vector< unsigned char > key
Definition: psbt.h:103
bool operator==(const PSBTProprietary &b) const
Definition: psbt.h:109
Instructions for how a PSBT should be signed or filled with information.
Definition: types.h:32
Dummy data type to identify deserializing constructors.
Definition: serialize.h:50
FuzzedDataProvider provider
Definition: dbwrapper.cpp:388
assert(!tx.IsCoinBase())