-
Notifications
You must be signed in to change notification settings - Fork 331
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
39 changed files
with
289 additions
and
365 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,76 +1,9 @@ | ||
[package] | ||
name = "bdk" | ||
version = "0.27.0" | ||
edition = "2018" | ||
authors = ["Alekos Filini <[email protected]>", "Riccardo Casatta <[email protected]>"] | ||
homepage = "https://bitcoindevkit.org" | ||
repository = "https://github.com/bitcoindevkit/bdk" | ||
documentation = "https://docs.rs/bdk" | ||
description = "A modern, lightweight, descriptor-based wallet library" | ||
keywords = ["bitcoin", "wallet", "descriptor", "psbt"] | ||
readme = "README.md" | ||
license = "MIT OR Apache-2.0" | ||
# TODO: remove this when examples all work | ||
autoexamples = false | ||
|
||
[dependencies] | ||
log = "^0.4" | ||
miniscript = { version = "9", features = ["serde"] } | ||
bitcoin = { version = "0.29", features = ["serde", "base64", "rand"] } | ||
serde = { version = "^1.0", features = ["derive"] } | ||
serde_json = { version = "^1.0" } | ||
bdk_chain = { version = "0.1", features = ["miniscript", "serde"] } | ||
rand = "^0.8" | ||
|
||
# Optional dependencies | ||
hwi = { version = "0.5", optional = true, features = [ "use-miniscript"] } | ||
bip39 = { version = "1.0.1", optional = true } | ||
|
||
[target.'cfg(target_arch = "wasm32")'.dependencies] | ||
getrandom = "0.2" | ||
js-sys = "0.3" | ||
|
||
[features] | ||
default = ["std"] | ||
std = [] | ||
file-store = [ "std", "bdk_chain/file_store"] | ||
compiler = ["miniscript/compiler"] | ||
all-keys = ["keys-bip39"] | ||
keys-bip39 = ["bip39"] | ||
hardware-signer = ["hwi"] | ||
|
||
# Debug/Test features | ||
test-md-docs = [] | ||
test-hardware-signer = ["hardware-signer"] | ||
|
||
# This feature is used to run `cargo check` in our CI targeting wasm. It's not recommended | ||
# for libraries to explicitly include the "getrandom/js" feature, so we only do it when | ||
# necessary for running our CI. See: https://docs.rs/getrandom/0.2.8/getrandom/#webassembly-support | ||
dev-getrandom-wasm = ["getrandom/js"] | ||
|
||
[dev-dependencies] | ||
lazy_static = "1.4" | ||
env_logger = "0.7" | ||
# Move back to importing from rust-bitcoin once https://github.com/rust-bitcoin/rust-bitcoin/pull/1342 is released | ||
base64 = "^0.13" | ||
assert_matches = "1.5.0" | ||
|
||
[[example]] | ||
name = "miniscriptc" | ||
path = "examples/compiler.rs" | ||
required-features = ["compiler"] | ||
|
||
[[example]] | ||
name = "policy" | ||
path = "examples/policy.rs" | ||
required-features = ["std"] | ||
|
||
[[example]] | ||
name = "mnemonic_to_descriptors" | ||
path = "examples/mnemonic_to_descriptors.rs" | ||
required-features = ["all-keys"] | ||
|
||
[package.metadata.docs.rs] | ||
all-features = true | ||
# defines the configuration attribute `docsrs` | ||
rustdoc-args = ["--cfg", "docsrs"] | ||
[workspace] | ||
members = [ | ||
"crates/bdk", | ||
"example-crates/esplora-wallet", | ||
"example-crates/electrum-wallet", | ||
] | ||
|
||
[workspace.package] | ||
authors = ["Bitcoin Dev Kit Developers"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,197 +1,18 @@ | ||
<div align="center"> | ||
<h1>BDK</h1> | ||
# The Bitcoin Dev Kit | ||
|
||
<img src="./static/bdk.png" width="220" /> | ||
The `bdk` libraries aims to be the core building block for Bitcoin wallets of any kind. | ||
|
||
<p> | ||
<strong>A modern, lightweight, descriptor-based wallet library written in Rust!</strong> | ||
</p> | ||
The Bitcoin Dev Kit developers are in the process of releasing `v1.0` which is a fundamental | ||
re-write of how the library works. | ||
|
||
<p> | ||
<a href="https://crates.io/crates/bdk"><img alt="Crate Info" src="https://img.shields.io/crates/v/bdk.svg"/></a> | ||
<a href="https://github.com/bitcoindevkit/bdk/blob/master/LICENSE"><img alt="MIT or Apache-2.0 Licensed" src="https://img.shields.io/badge/license-MIT%2FApache--2.0-blue.svg"/></a> | ||
<a href="https://github.com/bitcoindevkit/bdk/actions?query=workflow%3ACI"><img alt="CI Status" src="https://github.com/bitcoindevkit/bdk/workflows/CI/badge.svg"></a> | ||
<a href="https://coveralls.io/github/bitcoindevkit/bdk?branch=master"><img src="https://coveralls.io/repos/github/bitcoindevkit/bdk/badge.svg?branch=master"/></a> | ||
<a href="https://docs.rs/bdk"><img alt="API Docs" src="https://img.shields.io/badge/docs.rs-bdk-green"/></a> | ||
<a href="https://blog.rust-lang.org/2021/12/02/Rust-1.57.0.html"><img alt="Rustc Version 1.57.0+" src="https://img.shields.io/badge/rustc-1.57.0%2B-lightgrey.svg"/></a> | ||
<a href="https://discord.gg/d7NkDKm"><img alt="Chat on Discord" src="https://img.shields.io/discord/753336465005608961?logo=discord"></a> | ||
</p> | ||
See for some background on this project: https://bitcoindevkit.org/blog/road-to-bdk-1/ (ignore the timeline 😁) | ||
|
||
<h4> | ||
<a href="https://bitcoindevkit.org">Project Homepage</a> | ||
<span> | </span> | ||
<a href="https://docs.rs/bdk">Documentation</a> | ||
</h4> | ||
</div> | ||
For a release timeline see the [`bdk_core_staging`] repo where a lot of the component work is being done. The plan is that everything in the `bdk_core_staging` repo will be moved into the `crates` directory here. | ||
|
||
## About | ||
|
||
The `bdk` library aims to be the core building block for Bitcoin wallets of any kind. | ||
[`bdk_core_staging`]: https://github.com/LLFourn/bdk_core_staging | ||
|
||
* It uses [Miniscript](https://github.com/rust-bitcoin/rust-miniscript) to support descriptors with generalized conditions. This exact same library can be used to build | ||
single-sig wallets, multisigs, timelocked contracts and more. | ||
* It supports multiple blockchain backends and databases, allowing developers to choose exactly what's right for their projects. | ||
* It's built to be cross-platform: the core logic works on desktop, mobile, and even WebAssembly. | ||
* It's very easy to extend: developers can implement customized logic for blockchain backends, databases, signers, coin selection, and more, without having to fork and modify this library. | ||
|
||
## Examples | ||
|
||
### Sync the balance of a descriptor | ||
|
||
```rust,no_run | ||
use bdk::Wallet; | ||
use bdk::blockchain::ElectrumBlockchain; | ||
use bdk::SyncOptions; | ||
use bdk::electrum_client::Client; | ||
use bdk::bitcoin::Network; | ||
|
||
fn main() -> Result<(), bdk::Error> { | ||
let blockchain = ElectrumBlockchain::from(Client::new("ssl://electrum.blockstream.info:60002")?); | ||
let wallet = Wallet::new( | ||
"wpkh([c258d2e4/84h/1h/0h]tpubDDYkZojQFQjht8Tm4jsS3iuEmKjTiEGjG6KnuFNKKJb5A6ZUCUZKdvLdSDWofKi4ToRCwb9poe1XdqfUnP4jaJjCB2Zwv11ZLgSbnZSNecE/0/*)", | ||
Some("wpkh([c258d2e4/84h/1h/0h]tpubDDYkZojQFQjht8Tm4jsS3iuEmKjTiEGjG6KnuFNKKJb5A6ZUCUZKdvLdSDWofKi4ToRCwb9poe1XdqfUnP4jaJjCB2Zwv11ZLgSbnZSNecE/1/*)"), | ||
Network::Testnet, | ||
)?; | ||
wallet.sync(&blockchain, SyncOptions::default())?; | ||
println!("Descriptor balance: {} SAT", wallet.get_balance()?); | ||
Ok(()) | ||
} | ||
``` | ||
|
||
### Generate a few addresses | ||
|
||
```rust | ||
use bdk::Wallet; | ||
use bdk::wallet::AddressIndex::New; | ||
use bdk::bitcoin::Network; | ||
|
||
fn main() -> Result<(), bdk::Error> { | ||
let wallet = Wallet::new_no_persist( | ||
"wpkh([c258d2e4/84h/1h/0h]tpubDDYkZojQFQjht8Tm4jsS3iuEmKjTiEGjG6KnuFNKKJb5A6ZUCUZKdvLdSDWofKi4ToRCwb9poe1XdqfUnP4jaJjCB2Zwv11ZLgSbnZSNecE/0/*)", | ||
Some("wpkh([c258d2e4/84h/1h/0h]tpubDDYkZojQFQjht8Tm4jsS3iuEmKjTiEGjG6KnuFNKKJb5A6ZUCUZKdvLdSDWofKi4ToRCwb9poe1XdqfUnP4jaJjCB2Zwv11ZLgSbnZSNecE/1/*)"), | ||
Network::Testnet, | ||
)?; | ||
|
||
println!("Address #0: {}", wallet.get_address(New)); | ||
println!("Address #1: {}", wallet.get_address(New)); | ||
println!("Address #2: {}", wallet.get_address(New)); | ||
|
||
Ok(()) | ||
} | ||
``` | ||
|
||
### Create a transaction | ||
|
||
```rust,no_run | ||
use bdk::{FeeRate, Wallet, SyncOptions}; | ||
use bdk::blockchain::ElectrumBlockchain; | ||
use bdk::electrum_client::Client; | ||
use bdk::wallet::AddressIndex::New; | ||
use base64; | ||
use bdk::bitcoin::consensus::serialize; | ||
use bdk::bitcoin::Network; | ||
fn main() -> Result<(), bdk::Error> { | ||
let blockchain = ElectrumBlockchain::from(Client::new("ssl://electrum.blockstream.info:60002")?); | ||
let wallet = Wallet::new_no_persist( | ||
"wpkh([c258d2e4/84h/1h/0h]tpubDDYkZojQFQjht8Tm4jsS3iuEmKjTiEGjG6KnuFNKKJb5A6ZUCUZKdvLdSDWofKi4ToRCwb9poe1XdqfUnP4jaJjCB2Zwv11ZLgSbnZSNecE/0/*)", | ||
Some("wpkh([c258d2e4/84h/1h/0h]tpubDDYkZojQFQjht8Tm4jsS3iuEmKjTiEGjG6KnuFNKKJb5A6ZUCUZKdvLdSDWofKi4ToRCwb9poe1XdqfUnP4jaJjCB2Zwv11ZLgSbnZSNecE/1/*)"), | ||
Network::Testnet, | ||
)?; | ||
wallet.sync(&blockchain, SyncOptions::default())?; | ||
let send_to = wallet.get_address(New); | ||
let (psbt, details) = { | ||
let mut builder = wallet.build_tx(); | ||
builder | ||
.add_recipient(send_to.script_pubkey(), 50_000) | ||
.enable_rbf() | ||
.do_not_spend_change() | ||
.fee_rate(FeeRate::from_sat_per_vb(5.0)); | ||
builder.finish()? | ||
}; | ||
println!("Transaction details: {:#?}", details); | ||
println!("Unsigned PSBT: {}", base64::encode(&serialize(&psbt))); | ||
Ok(()) | ||
} | ||
``` | ||
|
||
### Sign a transaction | ||
|
||
```rust,no_run | ||
use bdk::{Wallet, SignOptions}; | ||
use base64; | ||
use bdk::bitcoin::consensus::deserialize; | ||
use bdk::bitcoin::Network; | ||
fn main() -> Result<(), bdk::Error> { | ||
let wallet = Wallet::new_no_persist( | ||
"wpkh([c258d2e4/84h/1h/0h]tprv8griRPhA7342zfRyB6CqeKF8CJDXYu5pgnj1cjL1u2ngKcJha5jjTRimG82ABzJQ4MQe71CV54xfn25BbhCNfEGGJZnxvCDQCd6JkbvxW6h/0/*)", | ||
Some("wpkh([c258d2e4/84h/1h/0h]tprv8griRPhA7342zfRyB6CqeKF8CJDXYu5pgnj1cjL1u2ngKcJha5jjTRimG82ABzJQ4MQe71CV54xfn25BbhCNfEGGJZnxvCDQCd6JkbvxW6h/1/*)"), | ||
Network::Testnet, | ||
)?; | ||
let psbt = "..."; | ||
let mut psbt = deserialize(&base64::decode(psbt).unwrap())?; | ||
let _finalized = wallet.sign(&mut psbt, SignOptions::default())?; | ||
Ok(()) | ||
} | ||
``` | ||
|
||
## Testing | ||
|
||
### Unit testing | ||
|
||
```bash | ||
cargo test | ||
``` | ||
|
||
### Integration testing | ||
|
||
Integration testing require testing features, for example: | ||
|
||
```bash | ||
cargo test --features test-electrum | ||
``` | ||
|
||
The other options are `test-esplora`, `test-rpc` or `test-rpc-legacy` which runs against an older version of Bitcoin Core. | ||
Note that `electrs` and `bitcoind` binaries are automatically downloaded (on mac and linux), to specify you already have installed binaries you must use `--no-default-features` and provide `BITCOIND_EXE` and `ELECTRS_EXE` as environment variables. | ||
|
||
## Running under WASM | ||
|
||
If you want to run this library under WASM you will probably have to add the following lines to you `Cargo.toml`: | ||
|
||
```toml | ||
[dependencies] | ||
getrandom = { version = "0.2", features = ["js"] } | ||
``` | ||
|
||
This enables the `rand` crate to work in environments where JavaScript is available. See [this link](https://docs.rs/getrandom/0.2.8/getrandom/#webassembly-support) to learn more. | ||
|
||
## License | ||
|
||
Licensed under either of | ||
|
||
* Apache License, Version 2.0 | ||
([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) | ||
* MIT license | ||
([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) | ||
|
||
at your option. | ||
|
||
## Contribution | ||
|
||
Unless you explicitly state otherwise, any contribution intentionally submitted | ||
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be | ||
dual licensed as above, without any additional terms or conditions. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
[package] | ||
name = "bdk" | ||
homepage = "https://bitcoindevkit.org" | ||
version = "1.0.0-alpha.0" | ||
repository = "https://github.com/bitcoindevkit/bdk" | ||
documentation = "https://docs.rs/bdk" | ||
description = "A modern, lightweight, descriptor-based wallet library" | ||
keywords = ["bitcoin", "wallet", "descriptor", "psbt"] | ||
readme = "README.md" | ||
license = "MIT OR Apache-2.0" | ||
authors.workspace = true | ||
edition = "2018" | ||
|
||
|
||
[dependencies] | ||
log = "^0.4" | ||
rand = "^0.8" | ||
miniscript = { version = "9", features = ["serde"] } | ||
bitcoin = { version = "0.29", features = ["serde", "base64", "rand"] } | ||
serde = { version = "^1.0", features = ["derive"] } | ||
serde_json = { version = "^1.0" } | ||
bdk_chain = { version = "0.1", features = ["miniscript", "serde"] } | ||
|
||
# Optional dependencies | ||
hwi = { version = "0.5", optional = true, features = [ "use-miniscript"] } | ||
bip39 = { version = "1.0.1", optional = true } | ||
|
||
[target.'cfg(target_arch = "wasm32")'.dependencies] | ||
getrandom = "0.2" | ||
js-sys = "0.3" | ||
|
||
|
||
[features] | ||
default = ["std"] | ||
std = [] | ||
file-store = [ "std", "bdk_chain/file_store"] | ||
compiler = ["miniscript/compiler"] | ||
all-keys = ["keys-bip39"] | ||
keys-bip39 = ["bip39"] | ||
hardware-signer = ["hwi"] | ||
|
||
[dev-dependencies] | ||
lazy_static = "1.4" | ||
env_logger = "0.7" | ||
# Move back to importing from rust-bitcoin once https://github.com/rust-bitcoin/rust-bitcoin/pull/1342 is released | ||
base64 = "^0.13" | ||
assert_matches = "1.5.0" | ||
|
||
|
||
[package.metadata.docs.rs] | ||
all-features = true | ||
rustdoc-args = ["--cfg", "docsrs"] | ||
|
||
|
||
[[example]] | ||
name = "mnemonic_to_descriptors" | ||
path = "examples/mnemonic_to_descriptors.rs" | ||
required-features = ["all-keys"] | ||
|
||
[[example]] | ||
name = "miniscriptc" | ||
path = "examples/compiler.rs" | ||
required-features = ["compiler"] |
File renamed without changes.
File renamed without changes.
File renamed without changes.
Oops, something went wrong.