2021-10-11 23:04:18 -07:00
|
|
|
use bdk::bitcoin::Network;
|
2021-10-12 11:53:11 -07:00
|
|
|
use bdk::sled;
|
|
|
|
use bdk::sled::Tree;
|
2021-10-12 18:22:02 -07:00
|
|
|
use bdk::wallet::AddressIndex;
|
2021-10-14 00:05:50 +05:30
|
|
|
use bdk::Error;
|
2021-10-12 18:22:02 -07:00
|
|
|
use bdk::Wallet;
|
|
|
|
use std::sync::Mutex;
|
2021-10-11 23:04:18 -07:00
|
|
|
|
2021-10-14 00:05:50 +05:30
|
|
|
type BdkError = Error;
|
|
|
|
|
2021-10-11 23:04:18 -07:00
|
|
|
uniffi_macros::include_scaffolding!("bdk");
|
|
|
|
|
|
|
|
struct OfflineWallet {
|
2021-10-12 11:53:11 -07:00
|
|
|
wallet: Mutex<Wallet<(), Tree>>,
|
2021-10-11 23:04:18 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
impl OfflineWallet {
|
2021-10-14 00:05:50 +05:30
|
|
|
fn new(descriptor: String) -> Result<Self, BdkError> {
|
2021-10-12 11:53:11 -07:00
|
|
|
let database = sled::open("testdb").unwrap();
|
|
|
|
let tree = database.open_tree("test").unwrap();
|
2021-10-14 00:05:50 +05:30
|
|
|
let wallet = Mutex::new(Wallet::new_offline(
|
|
|
|
&descriptor,
|
|
|
|
None,
|
|
|
|
Network::Regtest,
|
|
|
|
tree,
|
|
|
|
)?);
|
|
|
|
Ok(OfflineWallet { wallet })
|
2021-10-11 23:04:18 -07:00
|
|
|
}
|
2021-10-13 01:45:22 +05:30
|
|
|
|
|
|
|
fn get_new_address(&self) -> String {
|
2021-10-12 18:22:02 -07:00
|
|
|
self.wallet
|
2021-10-13 01:45:22 +05:30
|
|
|
.lock()
|
|
|
|
.unwrap()
|
|
|
|
.get_address(AddressIndex::New)
|
|
|
|
.unwrap()
|
|
|
|
.address
|
|
|
|
.to_string()
|
|
|
|
}
|
2021-06-03 17:51:07 -07:00
|
|
|
}
|
2021-10-11 23:04:18 -07:00
|
|
|
|
2021-10-12 11:53:11 -07:00
|
|
|
uniffi::deps::static_assertions::assert_impl_all!(OfflineWallet: Sync, Send);
|