pub struct Wpkh<Pk: MiniscriptKey> { /* private fields */ }Expand description
A bare Wpkh descriptor at top level
Implementations§
Source§impl<Pk: MiniscriptKey> Wpkh<Pk>
impl<Pk: MiniscriptKey> Wpkh<Pk>
Sourcepub fn into_inner(self) -> Pk
pub fn into_inner(self) -> Pk
Get the inner key
Sourcepub fn to_string_no_checksum(&self) -> String
👎Deprecated since 8.0.0: use format!(“{:#}”) instead
pub fn to_string_no_checksum(&self) -> String
Get the descriptor without the checksum
Sourcepub fn sanity_check(&self) -> Result<(), Error>
pub fn sanity_check(&self) -> Result<(), Error>
Checks whether the descriptor is safe.
Sourcepub fn max_satisfaction_weight(&self) -> usize
pub fn max_satisfaction_weight(&self) -> usize
Computes an upper bound on the weight of a satisfying witness to the transaction.
Assumes all ec-signatures are 73 bytes, including push opcode and sighash suffix. Includes the weight of the VarInts encoding the scriptSig and witness stack length.
Source§impl<Pk: MiniscriptKey + ToPublicKey> Wpkh<Pk>
impl<Pk: MiniscriptKey + ToPublicKey> Wpkh<Pk>
Sourcepub fn script_pubkey(&self) -> Script
pub fn script_pubkey(&self) -> Script
Obtains the corresponding script pubkey for this descriptor.
Sourcepub fn address(&self, network: Network) -> Address
pub fn address(&self, network: Network) -> Address
Obtains the corresponding script pubkey for this descriptor.
Sourcepub fn inner_script(&self) -> Script
pub fn inner_script(&self) -> Script
Obtains the underlying miniscript for this descriptor.
Sourcepub fn ecdsa_sighash_script_code(&self) -> Script
pub fn ecdsa_sighash_script_code(&self) -> Script
Obtains the pre bip-340 signature script code for this descriptor.
Sourcepub fn get_satisfaction<S>(
&self,
satisfier: S,
) -> Result<(Vec<Vec<u8>>, Script), Error>where
S: Satisfier<Pk>,
pub fn get_satisfaction<S>(
&self,
satisfier: S,
) -> Result<(Vec<Vec<u8>>, Script), Error>where
S: Satisfier<Pk>,
Returns satisfying non-malleable witness and scriptSig with minimum
weight to spend an output controlled by the given descriptor if it is
possible to construct one using the satisfier.
Sourcepub fn get_satisfaction_mall<S>(
&self,
satisfier: S,
) -> Result<(Vec<Vec<u8>>, Script), Error>where
S: Satisfier<Pk>,
pub fn get_satisfaction_mall<S>(
&self,
satisfier: S,
) -> Result<(Vec<Vec<u8>>, Script), Error>where
S: Satisfier<Pk>,
Returns satisfying, possibly malleable, witness and scriptSig with
minimum weight to spend an output controlled by the given descriptor if
it is possible to construct one using the satisfier.
Trait Implementations§
Source§impl<Pk: MiniscriptKey> Debug for Wpkh<Pk>
impl<Pk: MiniscriptKey> Debug for Wpkh<Pk>
Source§impl<Pk: MiniscriptKey> Display for Wpkh<Pk>
impl<Pk: MiniscriptKey> Display for Wpkh<Pk>
Source§impl<Pk: MiniscriptKey> ForEachKey<Pk> for Wpkh<Pk>
impl<Pk: MiniscriptKey> ForEachKey<Pk> for Wpkh<Pk>
Source§impl<Pk: MiniscriptKey> From<Wpkh<Pk>> for Descriptor<Pk>
impl<Pk: MiniscriptKey> From<Wpkh<Pk>> for Descriptor<Pk>
Source§impl<Pk> FromStr for Wpkh<Pk>where
Pk: MiniscriptKey + FromStr,
Pk::Sha256: FromStr,
Pk::Hash256: FromStr,
Pk::Ripemd160: FromStr,
Pk::Hash160: FromStr,
<Pk as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Sha256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Ripemd160 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash160 as FromStr>::Err: ToString,
impl<Pk> FromStr for Wpkh<Pk>where
Pk: MiniscriptKey + FromStr,
Pk::Sha256: FromStr,
Pk::Hash256: FromStr,
Pk::Ripemd160: FromStr,
Pk::Hash160: FromStr,
<Pk as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Sha256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Ripemd160 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash160 as FromStr>::Err: ToString,
Source§impl<Pk> FromTree for Wpkh<Pk>where
Pk: MiniscriptKey + FromStr,
Pk::Sha256: FromStr,
Pk::Hash256: FromStr,
Pk::Ripemd160: FromStr,
Pk::Hash160: FromStr,
<Pk as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Sha256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Ripemd160 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash160 as FromStr>::Err: ToString,
impl<Pk> FromTree for Wpkh<Pk>where
Pk: MiniscriptKey + FromStr,
Pk::Sha256: FromStr,
Pk::Hash256: FromStr,
Pk::Ripemd160: FromStr,
Pk::Hash160: FromStr,
<Pk as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Sha256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash256 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Ripemd160 as FromStr>::Err: ToString,
<<Pk as MiniscriptKey>::Hash160 as FromStr>::Err: ToString,
Source§impl<Pk: MiniscriptKey> Liftable<Pk> for Wpkh<Pk>
impl<Pk: MiniscriptKey> Liftable<Pk> for Wpkh<Pk>
Source§impl<Pk: Ord + MiniscriptKey> Ord for Wpkh<Pk>
impl<Pk: Ord + MiniscriptKey> Ord for Wpkh<Pk>
Source§impl<Pk: PartialOrd + MiniscriptKey> PartialOrd for Wpkh<Pk>
impl<Pk: PartialOrd + MiniscriptKey> PartialOrd for Wpkh<Pk>
Source§impl<P, Q> TranslatePk<P, Q> for Wpkh<P>where
P: MiniscriptKey,
Q: MiniscriptKey,
impl<P, Q> TranslatePk<P, Q> for Wpkh<P>where
P: MiniscriptKey,
Q: MiniscriptKey,
Source§fn translate_pk<T, E>(&self, t: &mut T) -> Result<Self::Output, E>where
T: Translator<P, Q, E>,
fn translate_pk<T, E>(&self, t: &mut T) -> Result<Self::Output, E>where
T: Translator<P, Q, E>,
Translator.