Browse Source

Use sqlite for BDK's database

fix-olivia-event-id
Thomas Eizinger 3 years ago
parent
commit
fa87ad90c6
No known key found for this signature in database GPG Key ID: 651AC83A6C6C8B96
  1. 5
      .gitignore
  2. 95
      Cargo.lock
  3. 2
      daemon/Cargo.toml
  4. 2
      daemon/src/maker.rs
  5. 2
      daemon/src/taker.rs
  6. 7
      daemon/src/wallet.rs

5
.gitignore

@ -17,9 +17,6 @@
.pnp.* .pnp.*
# Artifacts from running the daemons # Artifacts from running the daemons
/maker.sqlite /*.sqlite*
/maker_wallet_db/
/taker.sqlite
/taker_wallet_db/
/maker_seed /maker_seed
/taker_seed /taker_seed

95
Cargo.lock

@ -157,9 +157,9 @@ dependencies = [
"log", "log",
"miniscript", "miniscript",
"rand 0.7.3", "rand 0.7.3",
"rusqlite",
"serde", "serde",
"serde_json", "serde_json",
"sled",
"tokio", "tokio",
] ]
@ -424,15 +424,6 @@ version = "1.1.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ccaeedb56da03b09f598226e25e80088cb4cd25f316e6e4df7d695f0feeb1403" 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]] [[package]]
name = "crossbeam-channel" name = "crossbeam-channel"
version = "0.5.1" version = "0.5.1"
@ -443,19 +434,6 @@ dependencies = [
"crossbeam-utils", "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]] [[package]]
name = "crossbeam-queue" name = "crossbeam-queue"
version = "0.3.2" version = "0.3.2"
@ -646,6 +624,18 @@ version = "2.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "f7531096570974c3a9dcf9e4b8e1cede1ec26cf5046219fb3b9d897503b9be59" 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]] [[package]]
name = "figment" name = "figment"
version = "0.10.6" version = "0.10.6"
@ -688,16 +678,6 @@ dependencies = [
"percent-encoding", "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]] [[package]]
name = "fuchsia-cprng" name = "fuchsia-cprng"
version = "0.1.1" version = "0.1.1"
@ -815,15 +795,6 @@ dependencies = [
"slab", "slab",
] ]
[[package]]
name = "fxhash"
version = "0.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c31b6d751ae2c7f11320402d34e41349dd1016f8d5d45e48c4312bc8625af50c"
dependencies = [
"byteorder",
]
[[package]] [[package]]
name = "generator" name = "generator"
version = "0.6.25" version = "0.6.25"
@ -1183,15 +1154,6 @@ version = "2.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "308cc39be01b73d0d18f82a0e7b2a3df85245f84af96fdddc5d202d27e47b86a" 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]] [[package]]
name = "mime" name = "mime"
version = "0.3.16" version = "0.3.16"
@ -1913,6 +1875,21 @@ dependencies = [
"uncased", "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]] [[package]]
name = "rust-embed" name = "rust-embed"
version = "6.2.0" version = "6.2.0"
@ -2229,22 +2206,6 @@ version = "0.4.4"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c307a32c1c5c437f38c7fd45d753050587732ba8628319fbdf12a7e289ccc590" 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]] [[package]]
name = "smallvec" name = "smallvec"
version = "1.6.1" version = "1.6.1"

2
daemon/Cargo.toml

@ -7,7 +7,7 @@ edition = "2018"
anyhow = "1" anyhow = "1"
async-trait = "0.1.51" async-trait = "0.1.51"
atty = "0.2" 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" bytes = "1"
cfd_protocol = { path = "../cfd_protocol" } cfd_protocol = { path = "../cfd_protocol" }
clap = "3.0.0-beta.4" clap = "3.0.0-beta.4"

2
daemon/src/maker.rs

@ -90,7 +90,7 @@ async fn main() -> Result<()> {
let wallet = Wallet::new( let wallet = Wallet::new(
&opts.electrum, &opts.electrum,
&data_dir.join("maker_wallet_db"), &data_dir.join("maker_wallet.sqlite"),
ext_priv_key, ext_priv_key,
) )
.await?; .await?;

2
daemon/src/taker.rs

@ -94,7 +94,7 @@ async fn main() -> Result<()> {
let wallet = Wallet::new( let wallet = Wallet::new(
&opts.electrum, &opts.electrum,
&data_dir.join("taker_wallet_db"), &data_dir.join("taker_wallet.sqlite"),
ext_priv_key, ext_priv_key,
) )
.await?; .await?;

7
daemon/src/wallet.rs

@ -13,11 +13,9 @@ use std::sync::Arc;
use std::time::SystemTime; use std::time::SystemTime;
use tokio::sync::Mutex; use tokio::sync::Mutex;
const SLED_TREE_NAME: &str = "wallet";
#[derive(Clone)] #[derive(Clone)]
pub struct Wallet { pub struct Wallet {
wallet: Arc<Mutex<bdk::Wallet<ElectrumBlockchain, bdk::sled::Tree>>>, wallet: Arc<Mutex<bdk::Wallet<ElectrumBlockchain, bdk::database::SqliteDatabase>>>,
} }
#[derive(thiserror::Error, Debug, Clone, Copy)] #[derive(thiserror::Error, Debug, Clone, Copy)]
@ -33,8 +31,7 @@ impl Wallet {
let client = bdk::electrum_client::Client::new(electrum_rpc_url) let client = bdk::electrum_client::Client::new(electrum_rpc_url)
.context("Failed to initialize Electrum RPC client")?; .context("Failed to initialize Electrum RPC client")?;
// TODO: Replace with sqlite once https://github.com/bitcoindevkit/bdk/pull/376 is merged. let db = bdk::database::SqliteDatabase::new(wallet_dir.display().to_string());
let db = bdk::sled::open(wallet_dir)?.open_tree(SLED_TREE_NAME)?;
let wallet = bdk::Wallet::new( let wallet = bdk::Wallet::new(
bdk::template::Bip84(ext_priv_key, KeychainKind::External), bdk::template::Bip84(ext_priv_key, KeychainKind::External),

Loading…
Cancel
Save