• Stars
    star
    812
  • Rank 56,150 (Top 2 %)
  • Language
    Rust
  • License
    Other
  • Created almost 5 years ago
  • Updated 4 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A modern, lightweight, descriptor-based wallet library written in Rust!

The Bitcoin Dev Kit

BDK

A modern, lightweight, descriptor-based wallet library written in Rust!

Crate Info MIT or Apache-2.0 Licensed CI Status API Docs Rustc Version 1.63.0+ Chat on Discord

About

The bdk libraries aims to provide well engineered and reviewed components for Bitcoin based applications. It is built upon the excellent rust-bitcoin and rust-miniscript crates.

⚠ The Bitcoin Dev Kit developers are in the process of releasing a v1.0 which is a fundamental re-write of how the library works. See for some background on this project: https://bitcoindevkit.org/blog/road-to-bdk-1/ (ignore the timeline 😁) For a release timeline see the BDK 1.0 project page.

Architecture

The project is split up into several crates in the /crates directory:

  • bdk: Contains the central high level Wallet type that is built from the low-level mechanisms provided by the other components
  • chain: Tools for storing and indexing chain data
  • file_store: A (experimental) persistence backend for storing chain data in a single file.
  • esplora: Extends the esplora-client crate with methods to fetch chain data from an esplora HTTP server in the form that bdk_chain and Wallet can consume.
  • electrum: Extends the electrum-client crate with methods to fetch chain data from an electrum server in the form that bdk_chain and Wallet can consume.

Fully working examples of how to use these components are in /example-crates:

  • example_cli: Library used by the example_* crates. Provides utilities for syncing, showing the balance, generating addresses and creating transactions without using the bdk Wallet.
  • example_electrum: A command line Bitcoin wallet application built on top of example_cli and the electrum crate. It shows the power of the bdk tools (chain + file_store + electrum), without depending on the main bdk library.
  • example_esplora: A command line Bitcoin wallet application built on top of example_cli and the esplora crate. It shows the power of the bdk tools (chain + file_store + esplora), without depending on the main bdk library.
  • example_bitcoind_rpc_polling: A command line Bitcoin wallet application built on top of example_cli and the bitcoind_rpc crate. It shows the power of the bdk tools (chain + file_store + bitcoind_rpc), without depending on the main bdk library.
  • wallet_esplora_blocking: Uses the Wallet to sync and spend using the Esplora blocking interface.
  • wallet_esplora_async: Uses the Wallet to sync and spend using the Esplora asynchronous interface.
  • wallet_electrum: Uses the Wallet to sync and spend using Electrum.

Minimum Supported Rust Version (MSRV)

This library should compile with any combination of features with Rust 1.63.0.

To build with the MSRV you will need to pin dependencies as follows:

# zip 0.6.3 has MSRV 1.64.0
cargo update -p zip --precise "0.6.2"
# time 0.3.21 has MSRV 1.65.0
cargo update -p time --precise "0.3.20"
# jobserver 0.1.27 has MSRV 1.66.0
cargo update -p jobserver --precise "0.1.26"
# home 0.5.9 has MSRV 1.70.0
cargo update -p home --precise "0.5.5"
# proptest 1.4.0 has MSRV 1.65.0
cargo update -p proptest --precise "1.2.0"

License

Licensed under either of

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.

More Repositories

1

bdk-cli

A CLI wallet library and REPL tool to demo and test the BDK library
Rust
110
star
2

bdk-ffi

Please consider this project *experimental*.
Rust
88
star
3

rust-electrum-client

Bitcoin Electrum client library. Supports plaintext, TLS and Onion servers.
Rust
78
star
4

bitcoindevkit.org

BDK project home page (originally magicalbitcoin.org 🧙)
JavaScript
48
star
5

bdk-old

REPLACED BY REPO: bitcoindevkit/bdk
Rust
34
star
6

bdk-swift

Swift package for bdk-ffi
Swift
32
star
7

rust-hwi

Rust wrapper for the Bitcoin Core Hardware Wallet Interface
Rust
31
star
8

rust-esplora-client

Bitcoin Esplora API client library. Supports plaintext, TLS and Onion servers. Blocking or async.
Rust
28
star
9

book-of-bdk

Building a BDK walkthrough style book
Rust
23
star
10

elephant

Rust
20
star
11

BDKSwiftExampleWallet

BitcoinDevKit Swift Example Wallet
Swift
19
star
12

bdk-reserves

Proof-of-reserves for bitcoin-dev-kit
Rust
15
star
13

bdk-python

The Python language bindings for the Bitcoindevkit
Python
15
star
14

bdk-kotlin

Kotlin jvm + android packages for bdk-ffi
Kotlin
13
star
15

coin-select

Tool to help you select inputs for making bitcoin transactions.
Rust
12
star
16

bitcoin-ffi

Rust
12
star
17

bitcoin-regtest-box

Simple bitcoin regtest docker images for integration testing with github actions
Dockerfile
11
star
18

bitcoindevkit.org-old

REPLACED BY REPO: bitcoindevkit/bitcoindevkit.org
CSS
9
star
19

bdk-kotlin-example-wallet

The sample Android app for BDK.
Kotlin
8
star
20

bdk-jni

JNI bindings for bdk
Rust
8
star
21

awesome-bdk

An "Awesome List" for the Bitcoin Dev Kit Project
8
star
22

branch-and-bound-coin-selection

Branch and bound coin selection 💰 in Rust 🦀
Rust
7
star
23

libp2ep-archived

Rust implementation of pay-to-endpoint
Rust
6
star
24

.github

Community health files for the @bitcoindevkit organization
4
star
25

linux-live-image

Debian-based live linux image with bdk-cli and rusty-paper-wallet pre-installed
Shell
2
star
26

bitcoinfee.ml

Web-based bitcoin fee estimation using machine learning
Rust
2
star
27

bitcoin-fee-model

Rust
2
star
28

bdk-android-old

REPLACED BY REPO: bitcoindevkit/bdk-jni
Java
2
star
29

BDWallet

This project was created by a team of USC students for their CSCI401 "Capstone:Design and Construction of Large Software Systems" class.
Kotlin
2
star
30

blog-comments

Blog comments from https://bitcoindevkit.org/blog
1
star
31

bdk-android-app-old

REPLACED BY REPO: MagicalBitcoin/android-app
Kotlin
1
star