Functioning, minimal-viable binaries and libraries to perform a trustless, p2p Maxwell-Belcher Coinswap Protocol.
This library is currently under beta development and is in an experimental stage. There are known and unknown bugs. Mainnet use is strictly NOT recommended.
Additionally, note that this code is currently designed to run exclusively on Linux systems.
CoinSwap is a rust implementation of a variant of atomic-swap protocol, using HTLCs on Bitcoin. Read more at:
The repo contains a fully automated integration testing framework on Bitcoin Regtest. The bitcoin binary used for testing is included here.
Delete the bitcoind
binary to reduce the repository size if you don't intend to run the integration tests.
The integration tests are the best way to look at a working demonstration of the coinswap protocol, involving multiple makers, a taker and the directory server. All working over Tor by default. No pre-requisite setup is needed, other than rust and cargo.
Run all the integration tests by running:
$ cargo test --features=integration-test -- --nocapture
Each test in the tests folder covers a different edge-case situation and demonstrates how the taker and makers recover from various types of swap failures.
keep an eye on the logs, that's where all the actions are happening.
Play through a single test case, for example, standard_swap
, by running:
$ cargo test --features=integration-test --tests test_standard_coinswap -- --nocapture
The individual test names can be found in the test files.
For in-depth developer documentation on the coinswap protocol and implementation, consult the dev book.
The project is divided into distinct modules, each focused on specific functionalities.
docs/
src/
├─ bin/
├─ maker/
├─ market/
├─ protocol/
├─ taker/
tests/
Directory | Description |
---|---|
doc |
Contains all the project-related docs. The dev-book includes major developer salient points. |
src/taker |
Taker module houses its core logic in src/taker/api.rs and handles both Taker-related behaviors and most of the protocol-related logic. |
src/maker |
Encompasses Maker-specific logic and plays a relatively passive role compared to Taker. |
src/wallet |
Manages wallet-related operations, including storage and blockchain interaction. |
src/market |
Handles market-related logic, where Makers post their offers. |
src/protocol |
Contains utility functions, error handling, and messages for protocol communication. |
tests |
Contains integration tests. Describes behavior of various abort/malice cases. |
The project currently only compiles on Linux. Mac and Windows are not supported. To compile on Mac or Windows, consider using virtual machines.
- Basic protocol workflow with integration tests.
- Modularize protocol components.
- Refine logging information.
- Abort 1: Taker aborts after setup. Makers identify this, and gets their fund back via contract tx.
- Abort 2: One Maker aborts before setup. Taker retaliates by banning the maker, moving on with other makers, if it can't find enough makers, then recovering via contract transactions.
- Case 1: Maker drops before sending sender's signature. Taker tries with another Maker and moves on.
- Case 2: Maker drops before sending sender's signature. Taker doesn't have any new Maker. Recovers from swap.
- Case 3: Maker drops after sending sender's signatures. Taker doesn't have any new Maker. Recovers from swap.
- Build a flexible Test-Framework with
bitcoind
backend. - Abort 3: Maker aborts after setup. Taker and other Makers identify this and recovers back via contract tx. Taker bans the aborting Maker's fidelity bond.
- Case 1: Maker Drops at
ContractSigsForRecvrAndSender
. Does not broadcasts the funding txs. Taker and Other Maker recovers. Maker gets banned. - Case 2: Maker drops at
ContractSigsForRecvr
after broadcasting funding txs. Taker and other Makers recover. Maker gets banned. - Case 3: Maker Drops at
HashPreimage
message and doesn't respond back with privkeys. Taker and other Maker recovers. Maker gets banned.
- Case 1: Maker Drops at
- Malice 1: Taker broadcasts contract immaturely. Other Makers identify this, get their funds back via contract tx.
- Malice 2: One of the Makers broadcast contract immaturely. The Taker identify this, bans the Maker's fidelity bond, other Makers get back funds via contract tx.
- Fix all clippy warnings.
- Implement configuration file i/o support for Takers and Makers.
- Switch to binary encoding for network messages.
- Switch to binary encoding for wallet data.
- Clean up and integrate fidelity bonds with maker banning.
- Make tor detectable and connectable by default for Maker and Taker. And Tor configs to their config lists.
- Sketch a simple
Directory Server
. Tor must. This will act as the MVP DNS server. - Achieve >80% crate-level test coverage ratio (including integration tests).
- Turn maker server into a
maker
cli app, that spawns the server in the background, and exposes a basic maker wallet API. - Turn the taker into a
taker
cli app. This also has basic taker wallet API +do_coinswap()
which spawns a swap process in the background. - Create
swap_dns_server
as a stand-alone directory server binary. - A fresh
demo.md
doc to demonstrate a swap process withmaker
andtaker
andswap_dns_server
in Signet. - Release v0.1.0 in crates.io.
- Implement UTXO merging and branch-out via swap for improved UTXO management.
- Describe contract and funding transactions via miniscript, using BDK for wallet management.
- Enable wallet syncing via CBF (BIP157/158).
- Transition to taproot outputs for the entire protocol, enhancing anonymity and obfuscating contract transactions.
- Implement customizable wallet data storage (SQLite, Postgres).
- Optional: Payjoin integration via coinswap.
The project is under active development by a few motivated Rusty Bitcoin devs. Any contribution for features, tests, docs and other fixes/upgrades is encouraged and welcomed. The maintainers will use the PR thread to provide quick reviews and suggestions and are generally proactive at merging good contributions.
Few directions for new contributors:
-
The list of issues is a good place to look for contributable tasks and open problems.
-
Issues marked with
good first issue
are good places to get started for newbie Rust/Bitcoin devs. -
The docs are a good place to start reading up on the protocol.
-
Reviewing open PRs are a good place to start gathering a contextual understanding of the codebase.
-
Search for
TODO
s in the codebase to find in-line marked code todos and smaller improvements.
The repo contains pre-commit githooks to do auto-linting before commits. Set up the pre-commit hook by running:
ln -s ../../git_hooks/pre-commit .git/hooks/pre-commit
The dev community lurks in a Discord here.
Dev discussions predominantly happen via FOSS best practices, and by using Github as the Community Forum.
The Issues, PRs and Discussions are where all the hard lifting happening.