diff --git a/crates/bdk/src/wallet/mod.rs b/crates/bdk/src/wallet/mod.rs index 472369d980..5c8308b24d 100644 --- a/crates/bdk/src/wallet/mod.rs +++ b/crates/bdk/src/wallet/mod.rs @@ -225,6 +225,24 @@ impl Wallet { NewError::Persist(_) => unreachable!("no persistence so it can't fail"), }) } + + /// Infallibly return a derived address using the external descriptor, see [`AddressIndex`] for + /// available address index selection strategies. If none of the keys in the descriptor are derivable + /// (i.e. does not end with /*) then the same address will always be returned for any [`AddressIndex`]. + pub fn get_address(&mut self, address_index: AddressIndex) -> AddressInfo { + self.try_get_address(address_index).unwrap() + } + + /// Infallibly return a derived address using the internal (change) descriptor. + /// + /// If the wallet doesn't have an internal descriptor it will use the external descriptor. + /// + /// see [`AddressIndex`] for available address index selection strategies. If none of the keys + /// in the descriptor are derivable (i.e. does not end with /*) then the same address will always + /// be returned for any [`AddressIndex`]. + pub fn get_internal_address(&mut self, address_index: AddressIndex) -> AddressInfo { + self.try_get_internal_address(address_index).unwrap() + } } #[derive(Debug)] @@ -395,27 +413,37 @@ impl Wallet { /// Return a derived address using the external descriptor, see [`AddressIndex`] for /// available address index selection strategies. If none of the keys in the descriptor are derivable /// (i.e. does not end with /*) then the same address will always be returned for any [`AddressIndex`]. - pub fn get_address(&mut self, address_index: AddressIndex) -> AddressInfo + /// + /// A `PersistBackend::WriteError` will result if unable to persist the new address + /// to the `PersistBackend`. + pub fn try_get_address( + &mut self, + address_index: AddressIndex, + ) -> Result where D: PersistBackend, { self._get_address(KeychainKind::External, address_index) - .expect("persistence backend must not fail") } /// Return a derived address using the internal (change) descriptor. /// /// If the wallet doesn't have an internal descriptor it will use the external descriptor. /// + /// A `PersistBackend::WriteError` will result if unable to persist the new address + /// to the `PersistBackend`. + /// /// see [`AddressIndex`] for available address index selection strategies. If none of the keys /// in the descriptor are derivable (i.e. does not end with /*) then the same address will always /// be returned for any [`AddressIndex`]. - pub fn get_internal_address(&mut self, address_index: AddressIndex) -> AddressInfo + pub fn try_get_internal_address( + &mut self, + address_index: AddressIndex, + ) -> Result where D: PersistBackend, { self._get_address(KeychainKind::Internal, address_index) - .expect("persistence backend must not fail") } /// Return a derived address using the specified `keychain` (external/internal). diff --git a/example-crates/wallet_electrum/src/main.rs b/example-crates/wallet_electrum/src/main.rs index a6d7ca5206..d502b1dee6 100644 --- a/example-crates/wallet_electrum/src/main.rs +++ b/example-crates/wallet_electrum/src/main.rs @@ -29,7 +29,9 @@ fn main() -> Result<(), Box> { Network::Testnet, )?; - let address = wallet.get_address(bdk::wallet::AddressIndex::New); + let address = wallet + .try_get_address(bdk::wallet::AddressIndex::New) + .expect("new_address"); println!("Generated Address: {}", address); let balance = wallet.get_balance(); diff --git a/example-crates/wallet_esplora_async/src/main.rs b/example-crates/wallet_esplora_async/src/main.rs index ff1bbfb6d9..99e7f02831 100644 --- a/example-crates/wallet_esplora_async/src/main.rs +++ b/example-crates/wallet_esplora_async/src/main.rs @@ -27,7 +27,9 @@ async fn main() -> Result<(), Box> { Network::Testnet, )?; - let address = wallet.get_address(AddressIndex::New); + let address = wallet + .try_get_address(AddressIndex::New) + .expect("new address"); println!("Generated Address: {}", address); let balance = wallet.get_balance(); diff --git a/example-crates/wallet_esplora_blocking/src/main.rs b/example-crates/wallet_esplora_blocking/src/main.rs index 71554b0a81..717f04fafb 100644 --- a/example-crates/wallet_esplora_blocking/src/main.rs +++ b/example-crates/wallet_esplora_blocking/src/main.rs @@ -26,7 +26,9 @@ fn main() -> Result<(), Box> { Network::Testnet, )?; - let address = wallet.get_address(AddressIndex::New); + let address = wallet + .try_get_address(AddressIndex::New) + .expect("new address"); println!("Generated Address: {}", address); let balance = wallet.get_balance();