Struct Xpub
pub struct Xpub {
pub network: NetworkKind,
pub depth: u8,
pub parent_fingerprint: Fingerprint,
pub child_number: ChildNumber,
pub public_key: PublicKey,
pub chain_code: ChainCode,
}
Expand description
Extended public key
Fields§
§network: NetworkKind
The network kind this key is to be used on
depth: u8
How many derivations this key is from the master (which is 0)
parent_fingerprint: Fingerprint
Fingerprint of the parent key
child_number: ChildNumber
Child number of the key used to derive from parent (0 for master)
public_key: PublicKey
Public key
chain_code: ChainCode
Chain code
Implementations§
§impl Xpub
impl Xpub
pub fn from_priv<C>(secp: &Secp256k1<C>, sk: &Xpriv) -> Xpubwhere
C: Signing,
pub fn from_priv<C>(secp: &Secp256k1<C>, sk: &Xpriv) -> Xpubwhere
C: Signing,
Derives a public key from a private key
pub fn to_pub(self) -> CompressedPublicKey
pub fn to_pub(self) -> CompressedPublicKey
Constructs ECDSA compressed public key matching internal public key representation.
pub fn to_x_only_pub(self) -> XOnlyPublicKey
pub fn to_x_only_pub(self) -> XOnlyPublicKey
Constructs BIP340 x-only public key for BIP-340 signatures and Taproot use matching the internal public key representation.
pub fn derive_pub<C, P>(
&self,
secp: &Secp256k1<C>,
path: &P,
) -> Result<Xpub, Error>
pub fn derive_pub<C, P>( &self, secp: &Secp256k1<C>, path: &P, ) -> Result<Xpub, Error>
Attempts to derive an extended public key from a path.
The path
argument can be any type implementing AsRef<ChildNumber>
, such as DerivationPath
, for instance.
pub fn ckd_pub_tweak(
&self,
i: ChildNumber,
) -> Result<(SecretKey, ChainCode), Error>
pub fn ckd_pub_tweak( &self, i: ChildNumber, ) -> Result<(SecretKey, ChainCode), Error>
Compute the scalar tweak added to this key to get a child key
pub fn ckd_pub<C>(
&self,
secp: &Secp256k1<C>,
i: ChildNumber,
) -> Result<Xpub, Error>where
C: Verification,
pub fn ckd_pub<C>(
&self,
secp: &Secp256k1<C>,
i: ChildNumber,
) -> Result<Xpub, Error>where
C: Verification,
Public->Public child key derivation
pub fn decode(data: &[u8]) -> Result<Xpub, Error>
pub fn decode(data: &[u8]) -> Result<Xpub, Error>
Decoding extended public key from binary data according to BIP 32
pub fn identifier(&self) -> XKeyIdentifier
pub fn identifier(&self) -> XKeyIdentifier
Returns the HASH160 of the chaincode
pub fn fingerprint(&self) -> Fingerprint
pub fn fingerprint(&self) -> Fingerprint
Returns the first four bytes of the identifier