From a219d90dd0a00f717b28df8f39ce1b29ab2f0d28 Mon Sep 17 00:00:00 2001 From: Thomas Eizinger Date: Fri, 1 Oct 2021 09:58:41 +1000 Subject: [PATCH 1/3] Update to bdk 0.12 --- Cargo.lock | 10 ++++++---- cfd_protocol/Cargo.toml | 2 +- daemon/Cargo.toml | 2 +- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 7568679..ed9aa1a 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -145,8 +145,9 @@ dependencies = [ [[package]] name = "bdk" -version = "0.11.1-dev" -source = "git+https://github.com/bitcoindevkit/bdk/#8c21bcf40a1fe76637b65c3e483b6c46351f28fa" +version = "0.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ecf7e997526ceefbab7dd99fc0da6834ed8853bd051f53523415ed1dc82b870d" dependencies = [ "async-trait", "bdk-macros", @@ -164,8 +165,9 @@ dependencies = [ [[package]] name = "bdk-macros" -version = "0.5.0" -source = "git+https://github.com/bitcoindevkit/bdk/#8c21bcf40a1fe76637b65c3e483b6c46351f28fa" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "81c1980e50ae23bb6efa9283ae8679d6ea2c6fa6a99fe62533f65f4a25a1a56c" dependencies = [ "proc-macro2", "quote", diff --git a/cfd_protocol/Cargo.toml b/cfd_protocol/Cargo.toml index 3b648c4..8170ade 100644 --- a/cfd_protocol/Cargo.toml +++ b/cfd_protocol/Cargo.toml @@ -5,7 +5,7 @@ edition = "2018" [dependencies] anyhow = "1" -bdk = { git = "https://github.com/bitcoindevkit/bdk/" } +bdk = { version = "0.12" } bit-vec = "0.6" itertools = "0.10" rand = "0.6" diff --git a/daemon/Cargo.toml b/daemon/Cargo.toml index 82cdbfa..f52c2f5 100644 --- a/daemon/Cargo.toml +++ b/daemon/Cargo.toml @@ -7,7 +7,7 @@ edition = "2018" anyhow = "1" async-trait = "0.1.51" atty = "0.2" -bdk = { git = "https://github.com/bitcoindevkit/bdk/" } +bdk = { version = "0.12" } bytes = "1" cfd_protocol = { path = "../cfd_protocol" } clap = "3.0.0-beta.4" From 57fe104d9c8d3bbe781e3007552f193b0be0bd18 Mon Sep 17 00:00:00 2001 From: Thomas Eizinger Date: Fri, 1 Oct 2021 10:00:58 +1000 Subject: [PATCH 2/3] Selectively depend on bdk features --- cfd_protocol/Cargo.toml | 2 +- daemon/Cargo.toml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/cfd_protocol/Cargo.toml b/cfd_protocol/Cargo.toml index 8170ade..69def5c 100644 --- a/cfd_protocol/Cargo.toml +++ b/cfd_protocol/Cargo.toml @@ -5,7 +5,7 @@ edition = "2018" [dependencies] anyhow = "1" -bdk = { version = "0.12" } +bdk = { version = "0.12", default-features = false } bit-vec = "0.6" itertools = "0.10" rand = "0.6" diff --git a/daemon/Cargo.toml b/daemon/Cargo.toml index f52c2f5..123842e 100644 --- a/daemon/Cargo.toml +++ b/daemon/Cargo.toml @@ -7,7 +7,7 @@ edition = "2018" anyhow = "1" async-trait = "0.1.51" atty = "0.2" -bdk = { version = "0.12" } +bdk = { version = "0.12", default-features = false, features = ["key-value-db", "electrum"] } bytes = "1" cfd_protocol = { path = "../cfd_protocol" } clap = "3.0.0-beta.4" From fa87ad90c69e00f276ef95077b191c8fef631ad8 Mon Sep 17 00:00:00 2001 From: Thomas Eizinger Date: Fri, 1 Oct 2021 10:10:32 +1000 Subject: [PATCH 3/3] Use sqlite for BDK's database --- .gitignore | 5 +-- Cargo.lock | 95 +++++++++++++------------------------------- daemon/Cargo.toml | 2 +- daemon/src/maker.rs | 2 +- daemon/src/taker.rs | 2 +- daemon/src/wallet.rs | 7 +--- 6 files changed, 34 insertions(+), 79 deletions(-) diff --git a/.gitignore b/.gitignore index 5c0ccfb..41e4651 100644 --- a/.gitignore +++ b/.gitignore @@ -17,9 +17,6 @@ .pnp.* # Artifacts from running the daemons -/maker.sqlite -/maker_wallet_db/ -/taker.sqlite -/taker_wallet_db/ +/*.sqlite* /maker_seed /taker_seed diff --git a/Cargo.lock b/Cargo.lock index ed9aa1a..d2cc14f 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -157,9 +157,9 @@ dependencies = [ "log", "miniscript", "rand 0.7.3", + "rusqlite", "serde", "serde_json", - "sled", "tokio", ] @@ -424,15 +424,6 @@ version = "1.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ccaeedb56da03b09f598226e25e80088cb4cd25f316e6e4df7d695f0feeb1403" -[[package]] -name = "crc32fast" -version = "1.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "81156fece84ab6a9f2afdb109ce3ae577e42b1228441eded99bd77f627953b1a" -dependencies = [ - "cfg-if 1.0.0", -] - [[package]] name = "crossbeam-channel" version = "0.5.1" @@ -443,19 +434,6 @@ dependencies = [ "crossbeam-utils", ] -[[package]] -name = "crossbeam-epoch" -version = "0.9.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4ec02e091aa634e2c3ada4a392989e7c3116673ef0ac5b72232439094d73b7fd" -dependencies = [ - "cfg-if 1.0.0", - "crossbeam-utils", - "lazy_static", - "memoffset", - "scopeguard", -] - [[package]] name = "crossbeam-queue" version = "0.3.2" @@ -646,6 +624,18 @@ version = "2.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f7531096570974c3a9dcf9e4b8e1cede1ec26cf5046219fb3b9d897503b9be59" +[[package]] +name = "fallible-iterator" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4443176a9f2c162692bd3d352d745ef9413eec5782a80d8fd6f8a1ac692a07f7" + +[[package]] +name = "fallible-streaming-iterator" +version = "0.1.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7360491ce676a36bf9bb3c56c1aa791658183a54d2744120f27285738d90465a" + [[package]] name = "figment" version = "0.10.6" @@ -688,16 +678,6 @@ dependencies = [ "percent-encoding", ] -[[package]] -name = "fs2" -version = "0.4.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9564fc758e15025b46aa6643b1b77d047d1a56a1aea6e01002ac0c7026876213" -dependencies = [ - "libc", - "winapi 0.3.9", -] - [[package]] name = "fuchsia-cprng" version = "0.1.1" @@ -815,15 +795,6 @@ dependencies = [ "slab", ] -[[package]] -name = "fxhash" -version = "0.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c31b6d751ae2c7f11320402d34e41349dd1016f8d5d45e48c4312bc8625af50c" -dependencies = [ - "byteorder", -] - [[package]] name = "generator" version = "0.6.25" @@ -1183,15 +1154,6 @@ version = "2.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "308cc39be01b73d0d18f82a0e7b2a3df85245f84af96fdddc5d202d27e47b86a" -[[package]] -name = "memoffset" -version = "0.6.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "59accc507f1338036a0477ef61afdae33cde60840f4dfe481319ce3ad116ddf9" -dependencies = [ - "autocfg 1.0.1", -] - [[package]] name = "mime" version = "0.3.16" @@ -1913,6 +1875,21 @@ dependencies = [ "uncased", ] +[[package]] +name = "rusqlite" +version = "0.25.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "57adcf67c8faaf96f3248c2a7b419a0dbc52ebe36ba83dd57fe83827c1ea4eb3" +dependencies = [ + "bitflags", + "fallible-iterator", + "fallible-streaming-iterator", + "hashlink", + "libsqlite3-sys", + "memchr", + "smallvec", +] + [[package]] name = "rust-embed" version = "6.2.0" @@ -2229,22 +2206,6 @@ version = "0.4.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c307a32c1c5c437f38c7fd45d753050587732ba8628319fbdf12a7e289ccc590" -[[package]] -name = "sled" -version = "0.34.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f96b4737c2ce5987354855aed3797279def4ebf734436c6aa4552cf8e169935" -dependencies = [ - "crc32fast", - "crossbeam-epoch", - "crossbeam-utils", - "fs2", - "fxhash", - "libc", - "log", - "parking_lot", -] - [[package]] name = "smallvec" version = "1.6.1" diff --git a/daemon/Cargo.toml b/daemon/Cargo.toml index 123842e..22ea675 100644 --- a/daemon/Cargo.toml +++ b/daemon/Cargo.toml @@ -7,7 +7,7 @@ edition = "2018" anyhow = "1" async-trait = "0.1.51" atty = "0.2" -bdk = { version = "0.12", default-features = false, features = ["key-value-db", "electrum"] } +bdk = { version = "0.12", default-features = false, features = ["sqlite", "electrum"] } bytes = "1" cfd_protocol = { path = "../cfd_protocol" } clap = "3.0.0-beta.4" diff --git a/daemon/src/maker.rs b/daemon/src/maker.rs index 9eb5592..930ad6b 100644 --- a/daemon/src/maker.rs +++ b/daemon/src/maker.rs @@ -90,7 +90,7 @@ async fn main() -> Result<()> { let wallet = Wallet::new( &opts.electrum, - &data_dir.join("maker_wallet_db"), + &data_dir.join("maker_wallet.sqlite"), ext_priv_key, ) .await?; diff --git a/daemon/src/taker.rs b/daemon/src/taker.rs index 1e29145..77f1f49 100644 --- a/daemon/src/taker.rs +++ b/daemon/src/taker.rs @@ -94,7 +94,7 @@ async fn main() -> Result<()> { let wallet = Wallet::new( &opts.electrum, - &data_dir.join("taker_wallet_db"), + &data_dir.join("taker_wallet.sqlite"), ext_priv_key, ) .await?; diff --git a/daemon/src/wallet.rs b/daemon/src/wallet.rs index c5ce40b..e7c4008 100644 --- a/daemon/src/wallet.rs +++ b/daemon/src/wallet.rs @@ -13,11 +13,9 @@ use std::sync::Arc; use std::time::SystemTime; use tokio::sync::Mutex; -const SLED_TREE_NAME: &str = "wallet"; - #[derive(Clone)] pub struct Wallet { - wallet: Arc>>, + wallet: Arc>>, } #[derive(thiserror::Error, Debug, Clone, Copy)] @@ -33,8 +31,7 @@ impl Wallet { let client = bdk::electrum_client::Client::new(electrum_rpc_url) .context("Failed to initialize Electrum RPC client")?; - // TODO: Replace with sqlite once https://github.com/bitcoindevkit/bdk/pull/376 is merged. - let db = bdk::sled::open(wallet_dir)?.open_tree(SLED_TREE_NAME)?; + let db = bdk::database::SqliteDatabase::new(wallet_dir.display().to_string()); let wallet = bdk::Wallet::new( bdk::template::Bip84(ext_priv_key, KeychainKind::External),