Refactor: separate descriptor from lib.rs
This commit is contained in:
		
							parent
							
								
									dd58a9d548
								
							
						
					
					
						commit
						6fcb8985f1
					
				| @ -1,5 +1,5 @@ | ||||
| // use crate::BlockchainConfig;
 | ||||
| use crate::PartiallySignedTransaction; | ||||
| use crate::{PartiallySignedTransaction, BdkError}; | ||||
| use bdk::bitcoin::Network; | ||||
| use bdk::blockchain::any::{AnyBlockchain, AnyBlockchainConfig}; | ||||
| use bdk::blockchain::rpc::Auth as BdkAuth; | ||||
| @ -11,7 +11,6 @@ use bdk::blockchain::{ | ||||
|     electrum::ElectrumBlockchainConfig, esplora::EsploraBlockchainConfig, | ||||
|     rpc::RpcConfig as BdkRpcConfig, ConfigurableBlockchain, | ||||
| }; | ||||
| use bdk::Error as BdkError; | ||||
| use std::convert::{From, TryFrom}; | ||||
| use std::path::PathBuf; | ||||
| use std::sync::{Mutex, MutexGuard}; | ||||
|  | ||||
							
								
								
									
										194
									
								
								bdk-ffi/src/descriptor.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								bdk-ffi/src/descriptor.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,194 @@ | ||||
| use std::ops::Deref; | ||||
| use std::str::FromStr; | ||||
| use std::sync::Arc; | ||||
| use bdk::bitcoin::Network; | ||||
| use bdk::bitcoin::secp256k1::Secp256k1; | ||||
| use bdk::bitcoin::util::bip32::Fingerprint; | ||||
| use bdk::descriptor::{ExtendedDescriptor, IntoWalletDescriptor, KeyMap}; | ||||
| use bdk::KeychainKind; | ||||
| use bdk::template::{Bip44, Bip44Public, Bip49, Bip49Public, Bip84, Bip84Public, DescriptorTemplate}; | ||||
| use bdk::keys::{ | ||||
|     DescriptorPublicKey as BdkDescriptorPublicKey, | ||||
|     DescriptorSecretKey as BdkDescriptorSecretKey, | ||||
| }; | ||||
| use crate::{DescriptorPublicKey, DescriptorSecretKey, BdkError}; | ||||
| 
 | ||||
| #[derive(Debug)] | ||||
| pub(crate) struct Descriptor { | ||||
|     pub(crate) extended_descriptor: ExtendedDescriptor, | ||||
|     pub(crate) key_map: KeyMap, | ||||
| } | ||||
| 
 | ||||
| impl Descriptor { | ||||
|     pub(crate) fn new(descriptor: String, network: Network) -> Result<Self, BdkError> { | ||||
|         let secp = Secp256k1::new(); | ||||
|         let (extended_descriptor, key_map) = descriptor.into_wallet_descriptor(&secp, network)?; | ||||
|         Ok(Self { | ||||
|             extended_descriptor, | ||||
|             key_map, | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn new_bip44( | ||||
|         secret_key: Arc<DescriptorSecretKey>, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let derivable_key = secret_key.descriptor_secret_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorSecretKey::XPrv(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip44(derivable_key, keychain_kind).build(network).unwrap(); | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorSecretKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn new_bip44_public( | ||||
|         public_key: Arc<DescriptorPublicKey>, | ||||
|         fingerprint: String, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let fingerprint = Fingerprint::from_str(fingerprint.as_str()).unwrap(); | ||||
|         let derivable_key = public_key.descriptor_public_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorPublicKey::XPub(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip44Public(derivable_key, fingerprint, keychain_kind) | ||||
|                         .build(network) | ||||
|                         .unwrap(); | ||||
| 
 | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorPublicKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn new_bip49( | ||||
|         secret_key: Arc<DescriptorSecretKey>, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let derivable_key = secret_key.descriptor_secret_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorSecretKey::XPrv(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip49(derivable_key, keychain_kind).build(network).unwrap(); | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorSecretKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn new_bip49_public( | ||||
|         public_key: Arc<DescriptorPublicKey>, | ||||
|         fingerprint: String, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let fingerprint = Fingerprint::from_str(fingerprint.as_str()).unwrap(); | ||||
|         let derivable_key = public_key.descriptor_public_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorPublicKey::XPub(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip49Public(derivable_key, fingerprint, keychain_kind) | ||||
|                         .build(network) | ||||
|                         .unwrap(); | ||||
| 
 | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorPublicKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn new_bip84( | ||||
|         secret_key: Arc<DescriptorSecretKey>, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let derivable_key = secret_key.descriptor_secret_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorSecretKey::XPrv(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip84(derivable_key, keychain_kind).build(network).unwrap(); | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorSecretKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn new_bip84_public( | ||||
|         public_key: Arc<DescriptorPublicKey>, | ||||
|         fingerprint: String, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let fingerprint = Fingerprint::from_str(fingerprint.as_str()).unwrap(); | ||||
|         let derivable_key = public_key.descriptor_public_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorPublicKey::XPub(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip84Public(derivable_key, fingerprint, keychain_kind) | ||||
|                         .build(network) | ||||
|                         .unwrap(); | ||||
| 
 | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorPublicKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn as_string_private(&self) -> String { | ||||
|         let descriptor = &self.extended_descriptor; | ||||
|         let key_map = &self.key_map; | ||||
|         descriptor.to_string_with_secret(key_map) | ||||
|     } | ||||
| 
 | ||||
|     pub(crate) fn as_string(&self) -> String { | ||||
|         self.extended_descriptor.to_string() | ||||
|     } | ||||
| } | ||||
| @ -7,24 +7,20 @@ use crate::blockchain::{ | ||||
| }; | ||||
| use crate::psbt::PartiallySignedTransaction; | ||||
| use crate::wallet::{BumpFeeTxBuilder, TxBuilder, Wallet}; | ||||
| 
 | ||||
| use crate::descriptor::Descriptor; | ||||
| use bdk::bitcoin::blockdata::script::Script as BdkScript; | ||||
| use bdk::bitcoin::secp256k1::Secp256k1; | ||||
| use bdk::bitcoin::util::bip32::{DerivationPath as BdkDerivationPath, Fingerprint}; | ||||
| use bdk::bitcoin::util::bip32::{DerivationPath as BdkDerivationPath}; | ||||
| use bdk::bitcoin::{Address as BdkAddress, Network, OutPoint as BdkOutPoint, Txid}; | ||||
| use bdk::blockchain::Progress as BdkProgress; | ||||
| use bdk::database::any::{SledDbConfiguration, SqliteDbConfiguration}; | ||||
| use bdk::descriptor::{DescriptorXKey, ExtendedDescriptor, IntoWalletDescriptor}; | ||||
| use bdk::descriptor::{DescriptorXKey}; | ||||
| use bdk::keys::bip39::{Language, Mnemonic as BdkMnemonic, WordCount}; | ||||
| use bdk::keys::{ | ||||
|     DerivableKey, DescriptorPublicKey as BdkDescriptorPublicKey, | ||||
|     DescriptorSecretKey as BdkDescriptorSecretKey, ExtendedKey, GeneratableKey, GeneratedKey, | ||||
|     KeyMap, | ||||
| }; | ||||
| use bdk::miniscript::BareCtx; | ||||
| use bdk::template::{ | ||||
|     Bip44, Bip44Public, Bip49, Bip49Public, Bip84, Bip84Public, DescriptorTemplate, | ||||
| }; | ||||
| use bdk::wallet::AddressIndex as BdkAddressIndex; | ||||
| use bdk::wallet::AddressInfo as BdkAddressInfo; | ||||
| use bdk::{Balance as BdkBalance, BlockTime, Error as BdkError, FeeRate, KeychainKind}; | ||||
| @ -578,186 +574,6 @@ impl DescriptorPublicKey { | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #[derive(Debug)] | ||||
| struct Descriptor { | ||||
|     pub extended_descriptor: ExtendedDescriptor, | ||||
|     pub key_map: KeyMap, | ||||
| } | ||||
| 
 | ||||
| impl Descriptor { | ||||
|     fn new(descriptor: String, network: Network) -> Result<Self, BdkError> { | ||||
|         let secp = Secp256k1::new(); | ||||
|         let (extended_descriptor, key_map) = descriptor.into_wallet_descriptor(&secp, network)?; | ||||
|         Ok(Self { | ||||
|             extended_descriptor, | ||||
|             key_map, | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     fn new_bip44( | ||||
|         secret_key: Arc<DescriptorSecretKey>, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let derivable_key = secret_key.descriptor_secret_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorSecretKey::XPrv(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip44(derivable_key, keychain_kind).build(network).unwrap(); | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorSecretKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn new_bip44_public( | ||||
|         public_key: Arc<DescriptorPublicKey>, | ||||
|         fingerprint: String, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let fingerprint = Fingerprint::from_str(fingerprint.as_str()).unwrap(); | ||||
|         let derivable_key = public_key.descriptor_public_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorPublicKey::XPub(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip44Public(derivable_key, fingerprint, keychain_kind) | ||||
|                         .build(network) | ||||
|                         .unwrap(); | ||||
| 
 | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorPublicKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn new_bip49( | ||||
|         secret_key: Arc<DescriptorSecretKey>, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let derivable_key = secret_key.descriptor_secret_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorSecretKey::XPrv(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip49(derivable_key, keychain_kind).build(network).unwrap(); | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorSecretKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn new_bip49_public( | ||||
|         public_key: Arc<DescriptorPublicKey>, | ||||
|         fingerprint: String, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let fingerprint = Fingerprint::from_str(fingerprint.as_str()).unwrap(); | ||||
|         let derivable_key = public_key.descriptor_public_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorPublicKey::XPub(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip49Public(derivable_key, fingerprint, keychain_kind) | ||||
|                         .build(network) | ||||
|                         .unwrap(); | ||||
| 
 | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorPublicKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn new_bip84( | ||||
|         secret_key: Arc<DescriptorSecretKey>, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let derivable_key = secret_key.descriptor_secret_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorSecretKey::XPrv(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip84(derivable_key, keychain_kind).build(network).unwrap(); | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorSecretKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn new_bip84_public( | ||||
|         public_key: Arc<DescriptorPublicKey>, | ||||
|         fingerprint: String, | ||||
|         keychain_kind: KeychainKind, | ||||
|         network: Network, | ||||
|     ) -> Self { | ||||
|         let fingerprint = Fingerprint::from_str(fingerprint.as_str()).unwrap(); | ||||
|         let derivable_key = public_key.descriptor_public_key_mutex.lock().unwrap(); | ||||
| 
 | ||||
|         match derivable_key.deref() { | ||||
|             BdkDescriptorPublicKey::XPub(descriptor_x_key) => { | ||||
|                 let derivable_key = descriptor_x_key.xkey; | ||||
|                 let (extended_descriptor, key_map, _) = | ||||
|                     Bip84Public(derivable_key, fingerprint, keychain_kind) | ||||
|                         .build(network) | ||||
|                         .unwrap(); | ||||
| 
 | ||||
|                 Self { | ||||
|                     extended_descriptor, | ||||
|                     key_map, | ||||
|                 } | ||||
|             } | ||||
|             BdkDescriptorPublicKey::Single(_) => { | ||||
|                 unreachable!() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn as_string_private(&self) -> String { | ||||
|         let descriptor = &self.extended_descriptor; | ||||
|         let key_map = &self.key_map; | ||||
|         descriptor.to_string_with_secret(key_map) | ||||
|     } | ||||
| 
 | ||||
|     fn as_string(&self) -> String { | ||||
|         self.extended_descriptor.to_string() | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| uniffi::deps::static_assertions::assert_impl_all!(Wallet: Sync, Send); | ||||
| 
 | ||||
| // The goal of these tests to to ensure `bdk-ffi` intermediate code correctly calls `bdk` APIs.
 | ||||
|  | ||||
| @ -2,11 +2,10 @@ use bdk::bitcoin::hashes::hex::ToHex; | ||||
| use bdk::bitcoin::psbt::serialize::Serialize; | ||||
| use bdk::bitcoin::util::psbt::PartiallySignedTransaction as BdkPartiallySignedTransaction; | ||||
| use bdk::psbt::PsbtUtils; | ||||
| use bdk::Error as BdkError; | ||||
| use std::str::FromStr; | ||||
| use std::sync::{Arc, Mutex}; | ||||
| 
 | ||||
| use crate::FeeRate; | ||||
| use crate::{FeeRate, BdkError}; | ||||
| 
 | ||||
| #[derive(Debug)] | ||||
| pub(crate) struct PartiallySignedTransaction { | ||||
|  | ||||
| @ -4,7 +4,7 @@ use bdk::database::any::AnyDatabase; | ||||
| use bdk::database::{AnyDatabaseConfig, ConfigurableDatabase}; | ||||
| use bdk::wallet::tx_builder::ChangeSpendPolicy; | ||||
| use bdk::{ | ||||
|     Error as BdkError, FeeRate, SignOptions, SyncOptions as BdkSyncOptions, Wallet as BdkWallet, | ||||
|     FeeRate, SignOptions, SyncOptions as BdkSyncOptions, Wallet as BdkWallet, | ||||
| }; | ||||
| use std::collections::HashSet; | ||||
| use std::ops::Deref; | ||||
| @ -13,10 +13,11 @@ use std::sync::{Arc, Mutex, MutexGuard}; | ||||
| 
 | ||||
| use crate::blockchain::Blockchain; | ||||
| use crate::psbt::PartiallySignedTransaction; | ||||
| use crate::descriptor::Descriptor; | ||||
| use crate::{ | ||||
|     AddressIndex, AddressInfo, Balance, DatabaseConfig, Descriptor, LocalUtxo, NetworkLocalUtxo, | ||||
|     AddressIndex, AddressInfo, Balance, DatabaseConfig, LocalUtxo, NetworkLocalUtxo, | ||||
|     OutPoint, Progress, ProgressHolder, RbfValue, Script, ScriptAmount, TransactionDetails, | ||||
|     TxBuilderResult, | ||||
|     TxBuilderResult, BdkError, | ||||
| }; | ||||
| 
 | ||||
| #[derive(Debug)] | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user