if sign_options.remove_partial_sigs {
psbt_input.partial_sigs.clear();
}
+ if sign_options.remove_taproot_extras {
+ // We just constructed the final witness, clear these fields.
+ psbt_input.tap_key_sig = None;
+ psbt_input.tap_script_sigs.clear();
+ psbt_input.tap_scripts.clear();
+ psbt_input.tap_key_origins.clear();
+ psbt_input.tap_internal_key = None;
+ psbt_input.tap_merkle_root = None;
+ }
}
Err(_) => finished = false,
}
}
}
+ if finished && sign_options.remove_taproot_extras {
+ for output in &mut psbt.outputs {
+ output.tap_key_origins.clear();
+ }
+ }
+
Ok(finished)
}
/// Defaults to `true` which will remove partial signatures during finalization.
pub remove_partial_sigs: bool,
+ /// Whether to remove taproot specific fields from the PSBT on finalization.
+ ///
+ /// For inputs this includes the taproot internal key, merkle root, and individual
+ /// scripts and signatures. For both inputs and outputs it includes key origin info.
+ ///
+ /// Defaults to `true` which will remove all of the above mentioned fields when finalizing.
+ ///
+ /// See [`BIP371`](https://github.com/bitcoin/bips/blob/master/bip-0371.mediawiki) for details.
+ pub remove_taproot_extras: bool,
+
/// Whether to try finalizing the PSBT after the inputs are signed.
///
/// Defaults to `true` which will try finalizing PSBT after inputs are signed.
assume_height: None,
allow_all_sighashes: false,
remove_partial_sigs: true,
+ remove_taproot_extras: true,
try_finalize: true,
tap_leaves_options: TapLeavesOptions::default(),
sign_with_tap_internal_key: true,
});
}
+#[test]
+fn test_taproot_remove_tapfields_after_finalize_sign_option() {
+ let (mut wallet, _) = get_funded_wallet(get_test_tr_with_taptree());
+
+ let addr = wallet.get_address(New);
+ let mut builder = wallet.build_tx();
+ builder.drain_to(addr.script_pubkey()).drain_wallet();
+ let mut psbt = builder.finish().unwrap();
+ let finalized = wallet.sign(&mut psbt, SignOptions::default()).unwrap();
+ assert!(finalized);
+
+ // removes tap_* from inputs
+ for input in &psbt.inputs {
+ assert!(input.tap_key_sig.is_none());
+ assert!(input.tap_script_sigs.is_empty());
+ assert!(input.tap_scripts.is_empty());
+ assert!(input.tap_key_origins.is_empty());
+ assert!(input.tap_internal_key.is_none());
+ assert!(input.tap_merkle_root.is_none());
+ }
+ // removes key origins from outputs
+ for output in &psbt.outputs {
+ assert!(output.tap_key_origins.is_empty());
+ }
+}
+
#[test]
fn test_taproot_psbt_populate_tap_key_origins() {
let (mut wallet, _) = get_funded_wallet(get_test_tr_single_sig_xprv());