[descriptor] Expose utilities to deal with derived descriptors
This commit is contained in:
		
							parent
							
								
									0d9c2f76e0
								
							
						
					
					
						commit
						86abd8698f
					
				| @ -10,6 +10,41 @@ | |||||||
| // licenses.
 | // licenses.
 | ||||||
| 
 | 
 | ||||||
| //! Derived descriptor keys
 | //! Derived descriptor keys
 | ||||||
|  | //!
 | ||||||
|  | //! The [`DerivedDescriptorKey`] type is a wrapper over the standard [`DescriptorPublicKey`] which
 | ||||||
|  | //! guarantees that all the extended keys have a fixed derivation path, i.e. all the wildcards have
 | ||||||
|  | //! been replaced by actual derivation indexes.
 | ||||||
|  | //!
 | ||||||
|  | //! The [`AsDerived`] trait provides a quick way to derive descriptors to obtain a
 | ||||||
|  | //! `Descriptor<DerivedDescriptorKey>` type. This, in turn, can be used to derive public
 | ||||||
|  | //! keys for arbitrary derivation indexes.
 | ||||||
|  | //!
 | ||||||
|  | //! Combining this with [`Wallet::get_signers`], secret keys can also be derived.
 | ||||||
|  | //!
 | ||||||
|  | //! # Example
 | ||||||
|  | //!
 | ||||||
|  | //! ```
 | ||||||
|  | //! # use std::str::FromStr;
 | ||||||
|  | //! # use bitcoin::secp256k1::Secp256k1;
 | ||||||
|  | //! use bdk::descriptor::{AsDerived, DescriptorPublicKey};
 | ||||||
|  | //! use bdk::miniscript::{ToPublicKey, TranslatePk, MiniscriptKey};
 | ||||||
|  | //!
 | ||||||
|  | //! let secp = Secp256k1::gen_new();
 | ||||||
|  | //!
 | ||||||
|  | //! let key = DescriptorPublicKey::from_str("[aa600a45/84'/0'/0']tpubDCbDXFKoLTQp44wQuC12JgSn5g9CWGjZdpBHeTqyypZ4VvgYjTJmK9CkyR5bFvG9f4PutvwmvpYCLkFx2rpx25hiMs4sUgxJveW8ZzSAVAc/0/*")?;
 | ||||||
|  | //! let (descriptor, _, _) = bdk::descriptor!(wpkh(key))?;
 | ||||||
|  | //!
 | ||||||
|  | //! // derived: wpkh([aa600a45/84'/0'/0']tpubDCbDXFKoLTQp44wQuC12JgSn5g9CWGjZdpBHeTqyypZ4VvgYjTJmK9CkyR5bFvG9f4PutvwmvpYCLkFx2rpx25hiMs4sUgxJveW8ZzSAVAc/0/42)#3ladd0t2
 | ||||||
|  | //! let derived = descriptor.as_derived(42, &secp);
 | ||||||
|  | //! println!("derived: {}", derived);
 | ||||||
|  | //!
 | ||||||
|  | //! // with_pks: wpkh(02373ecb54c5e83bd7e0d40adf78b65efaf12fafb13571f0261fc90364eee22e1e)#p4jjgvll
 | ||||||
|  | //! let with_pks = derived.translate_pk_infallible(|pk| pk.to_public_key(), |pkh| pkh.to_public_key().to_pubkeyhash());
 | ||||||
|  | //! println!("with_pks: {}", with_pks);
 | ||||||
|  | //! # Ok::<(), Box<dyn std::error::Error>>(())
 | ||||||
|  | //! ```
 | ||||||
|  | //!
 | ||||||
|  | //! [`Wallet::get_signers`]: crate::wallet::Wallet::get_signers
 | ||||||
| 
 | 
 | ||||||
| use std::cmp::Ordering; | use std::cmp::Ordering; | ||||||
| use std::fmt; | use std::fmt; | ||||||
| @ -19,10 +54,7 @@ use std::ops::Deref; | |||||||
| use bitcoin::hashes::hash160; | use bitcoin::hashes::hash160; | ||||||
| use bitcoin::PublicKey; | use bitcoin::PublicKey; | ||||||
| 
 | 
 | ||||||
| pub use miniscript::{ | use miniscript::{descriptor::Wildcard, Descriptor, DescriptorPublicKey}; | ||||||
|     descriptor::KeyMap, descriptor::Wildcard, Descriptor, DescriptorPublicKey, Legacy, Miniscript, |  | ||||||
|     ScriptContext, Segwitv0, |  | ||||||
| }; |  | ||||||
| use miniscript::{MiniscriptKey, ToPublicKey, TranslatePk}; | use miniscript::{MiniscriptKey, ToPublicKey, TranslatePk}; | ||||||
| 
 | 
 | ||||||
| use crate::wallet::utils::SecpCtx; | use crate::wallet::utils::SecpCtx; | ||||||
| @ -119,14 +151,19 @@ impl<'s> ToPublicKey for DerivedDescriptorKey<'s> { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub(crate) trait AsDerived { | /// Utilities to derive descriptors
 | ||||||
|     // Derive a descriptor and transform all of its keys to `DerivedDescriptorKey`
 | ///
 | ||||||
|  | /// Check out the [module level] documentation for more.
 | ||||||
|  | ///
 | ||||||
|  | /// [module level]: crate::descriptor::derived
 | ||||||
|  | pub trait AsDerived { | ||||||
|  |     /// Derive a descriptor and transform all of its keys to `DerivedDescriptorKey`
 | ||||||
|     fn as_derived<'s>(&self, index: u32, secp: &'s SecpCtx) |     fn as_derived<'s>(&self, index: u32, secp: &'s SecpCtx) | ||||||
|         -> Descriptor<DerivedDescriptorKey<'s>>; |         -> Descriptor<DerivedDescriptorKey<'s>>; | ||||||
| 
 | 
 | ||||||
|     // Transform the keys into `DerivedDescriptorKey`.
 |     /// Transform the keys into `DerivedDescriptorKey`.
 | ||||||
|     //
 |     ///
 | ||||||
|     // Panics if the descriptor is not "fixed", i.e. if it's derivable
 |     /// Panics if the descriptor is not "fixed", i.e. if it's derivable
 | ||||||
|     fn as_derived_fixed<'s>(&self, secp: &'s SecpCtx) -> Descriptor<DerivedDescriptorKey<'s>>; |     fn as_derived_fixed<'s>(&self, secp: &'s SecpCtx) -> Descriptor<DerivedDescriptorKey<'s>>; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -21,16 +21,17 @@ use bitcoin::util::bip32::{ChildNumber, DerivationPath, ExtendedPubKey, Fingerpr | |||||||
| use bitcoin::util::psbt; | use bitcoin::util::psbt; | ||||||
| use bitcoin::{Network, PublicKey, Script, TxOut}; | use bitcoin::{Network, PublicKey, Script, TxOut}; | ||||||
| 
 | 
 | ||||||
| use miniscript::descriptor::{ | use miniscript::descriptor::{DescriptorType, InnerXKey}; | ||||||
|     DescriptorPublicKey, DescriptorType, DescriptorXKey, InnerXKey, Wildcard, | pub use miniscript::{ | ||||||
|  |     descriptor::DescriptorXKey, descriptor::KeyMap, descriptor::Wildcard, Descriptor, | ||||||
|  |     DescriptorPublicKey, Legacy, Miniscript, ScriptContext, Segwitv0, | ||||||
| }; | }; | ||||||
| pub use miniscript::{descriptor::KeyMap, Descriptor, Legacy, Miniscript, ScriptContext, Segwitv0}; |  | ||||||
| use miniscript::{DescriptorTrait, ForEachKey, TranslatePk}; | use miniscript::{DescriptorTrait, ForEachKey, TranslatePk}; | ||||||
| 
 | 
 | ||||||
| use crate::descriptor::policy::BuildSatisfaction; | use crate::descriptor::policy::BuildSatisfaction; | ||||||
| 
 | 
 | ||||||
| pub mod checksum; | pub mod checksum; | ||||||
| pub(crate) mod derived; | pub mod derived; | ||||||
| #[doc(hidden)] | #[doc(hidden)] | ||||||
| pub mod dsl; | pub mod dsl; | ||||||
| pub mod error; | pub mod error; | ||||||
| @ -38,8 +39,7 @@ pub mod policy; | |||||||
| pub mod template; | pub mod template; | ||||||
| 
 | 
 | ||||||
| pub use self::checksum::get_checksum; | pub use self::checksum::get_checksum; | ||||||
| use self::derived::AsDerived; | pub use self::derived::{AsDerived, DerivedDescriptorKey}; | ||||||
| pub use self::derived::DerivedDescriptorKey; |  | ||||||
| pub use self::error::Error as DescriptorError; | pub use self::error::Error as DescriptorError; | ||||||
| pub use self::policy::Policy; | pub use self::policy::Policy; | ||||||
| use self::template::DescriptorTemplateOut; | use self::template::DescriptorTemplateOut; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user