Struct bitcoin::util::sighash::SighashCache
source · pub struct SighashCache<T: Deref<Target = Transaction>> { /* private fields */ }
Expand description
Efficiently calculates signature hash message for legacy, segwit and taproot inputs.
Implementations§
source§impl<R: Deref<Target = Transaction>> SighashCache<R>
impl<R: Deref<Target = Transaction>> SighashCache<R>
sourcepub fn new(tx: R) -> Self
pub fn new(tx: R) -> Self
Constructs a new SighashCache
from an unsigned transaction.
The sighash components are computed in a lazy manner when required. For the generated sighashes to be valid, no fields in the transaction may change except for script_sig and witness.
sourcepub fn taproot_encode_signing_data_to<Write: Write, T: Borrow<TxOut>>(
&mut self,
writer: Write,
input_index: usize,
prevouts: &Prevouts<'_, T>,
annex: Option<Annex<'_>>,
leaf_hash_code_separator: Option<(TapLeafHash, u32)>,
sighash_type: SchnorrSighashType
) -> Result<(), Error>
pub fn taproot_encode_signing_data_to<Write: Write, T: Borrow<TxOut>>( &mut self, writer: Write, input_index: usize, prevouts: &Prevouts<'_, T>, annex: Option<Annex<'_>>, leaf_hash_code_separator: Option<(TapLeafHash, u32)>, sighash_type: SchnorrSighashType ) -> Result<(), Error>
Encodes the BIP341 signing data for any flag type into a given object implementing a
io::Write
trait.
sourcepub fn taproot_signature_hash<T: Borrow<TxOut>>(
&mut self,
input_index: usize,
prevouts: &Prevouts<'_, T>,
annex: Option<Annex<'_>>,
leaf_hash_code_separator: Option<(TapLeafHash, u32)>,
sighash_type: SchnorrSighashType
) -> Result<TapSighashHash, Error>
pub fn taproot_signature_hash<T: Borrow<TxOut>>( &mut self, input_index: usize, prevouts: &Prevouts<'_, T>, annex: Option<Annex<'_>>, leaf_hash_code_separator: Option<(TapLeafHash, u32)>, sighash_type: SchnorrSighashType ) -> Result<TapSighashHash, Error>
Computes the BIP341 sighash for any flag type.
sourcepub fn taproot_key_spend_signature_hash<T: Borrow<TxOut>>(
&mut self,
input_index: usize,
prevouts: &Prevouts<'_, T>,
sighash_type: SchnorrSighashType
) -> Result<TapSighashHash, Error>
pub fn taproot_key_spend_signature_hash<T: Borrow<TxOut>>( &mut self, input_index: usize, prevouts: &Prevouts<'_, T>, sighash_type: SchnorrSighashType ) -> Result<TapSighashHash, Error>
Computes the BIP341 sighash for a key spend.
sourcepub fn taproot_script_spend_signature_hash<S: Into<TapLeafHash>, T: Borrow<TxOut>>(
&mut self,
input_index: usize,
prevouts: &Prevouts<'_, T>,
leaf_hash: S,
sighash_type: SchnorrSighashType
) -> Result<TapSighashHash, Error>
pub fn taproot_script_spend_signature_hash<S: Into<TapLeafHash>, T: Borrow<TxOut>>( &mut self, input_index: usize, prevouts: &Prevouts<'_, T>, leaf_hash: S, sighash_type: SchnorrSighashType ) -> Result<TapSighashHash, Error>
Computes the BIP341 sighash for a script spend.
Assumes the default OP_CODESEPARATOR
position of 0xFFFFFFFF
. Custom values can be
provided through the more fine-grained API of SighashCache::taproot_encode_signing_data_to
.
sourcepub fn segwit_encode_signing_data_to<Write: Write>(
&mut self,
writer: Write,
input_index: usize,
script_code: &Script,
value: u64,
sighash_type: EcdsaSighashType
) -> Result<(), Error>
pub fn segwit_encode_signing_data_to<Write: Write>( &mut self, writer: Write, input_index: usize, script_code: &Script, value: u64, sighash_type: EcdsaSighashType ) -> Result<(), Error>
Encodes the BIP143 signing data for any flag type into a given object implementing a
std::io::Write
trait.
sourcepub fn segwit_signature_hash(
&mut self,
input_index: usize,
script_code: &Script,
value: u64,
sighash_type: EcdsaSighashType
) -> Result<Sighash, Error>
pub fn segwit_signature_hash( &mut self, input_index: usize, script_code: &Script, value: u64, sighash_type: EcdsaSighashType ) -> Result<Sighash, Error>
Computes the BIP143 sighash for any flag type.
sourcepub fn legacy_encode_signing_data_to<Write: Write, U: Into<u32>>(
&self,
writer: Write,
input_index: usize,
script_pubkey: &Script,
sighash_type: U
) -> EncodeSigningDataResult<Error>
pub fn legacy_encode_signing_data_to<Write: Write, U: Into<u32>>( &self, writer: Write, input_index: usize, script_pubkey: &Script, sighash_type: U ) -> EncodeSigningDataResult<Error>
Encodes the legacy signing data for any flag type into a given object implementing a
std::io::Write
trait. Internally calls Transaction::encode_signing_data_to
.
source§impl<R: DerefMut<Target = Transaction>> SighashCache<R>
impl<R: DerefMut<Target = Transaction>> SighashCache<R>
sourcepub fn witness_mut(&mut self, input_index: usize) -> Option<&mut Witness>
pub fn witness_mut(&mut self, input_index: usize) -> Option<&mut Witness>
When the SighashCache
is initialized with a mutable reference to a transaction instead of
a regular reference, this method is available to allow modification to the witnesses.
This allows in-line signing such as
use bitcoin::blockdata::transaction::{Transaction, EcdsaSighashType};
use bitcoin::util::sighash::SighashCache;
use bitcoin::{PackedLockTime, Script};
let mut tx_to_sign = Transaction { version: 2, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() };
let input_count = tx_to_sign.input.len();
let mut sig_hasher = SighashCache::new(&mut tx_to_sign);
for inp in 0..input_count {
let prevout_script = Script::new();
let _sighash = sig_hasher.segwit_signature_hash(inp, &prevout_script, 42, EcdsaSighashType::All);
// ... sign the sighash
sig_hasher.witness_mut(inp).unwrap().push(&Vec::new());
}