Skip to content

Latest commit

 

History

History
164 lines (104 loc) · 9.13 KB

README.md

File metadata and controls

164 lines (104 loc) · 9.13 KB

Coinswap

Functioning, minimal-viable binaries and libraries to perform a trustless, p2p Maxwell-Belcher Coinswap Protocol.

MIT or Apache-2.0 Licensed CI Status CI Status CI Status Coverage Rustc Version 1.75.0+

⚠️ Info

Coinswap v0.1.0 marketplace is now live on Testnet4.

⚠️ Warning

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.

About

Coinswap is a decentralized atomic swap protocol that enables trustless swaps of Bitcoin UTXOs through a decentralized, Sybil-resistant marketplace.

While atomic swaps are not new, existing solutions are centralized, rely on large swap servers, and inherently have the service provider as a single point of failure (SPOF) for censorship and privacy attacks. This project aims to implement atomic swaps via a decentralized market-based protocol.

The project builds on the work of many predecessors and is a continuation of Bitcoin researcher Chris Belcher's teleport-transactions. Since Belcher's prototype, the project has significantly matured, incorporating complete protocol handling, functional testing, Sybil resistance, and command-line applications, making it a practical swap solution for live networks.

Anyone can become a swap service provider (aka Maker) and earn fees by running the makerd app. Clients (aka Takers) can perform swaps with multiple makers using the taker app. A taker selects multiple makers from the market to swap with, splitting and routing swaps through various makers while maintaining privacy.

The system is designed with a smart-client-dumb-server philosophy, minimizing server requirements. This allows any home node operator to run makerd on their node box. The protocol employs fidelity bonds as a Sybil and DoS resistance mechanism for the market. Takers will avoid swapping with makers holding expired or invalid fidelity bonds.

Takers, acting as smart clients, handle critical roles such as coordinating swap rounds, validating data, managing interactions with multiple makers, and recovering swaps in case of errors. Makers, acting as dumb servers, respond to taker queries and do not communicate with each other. Instead, the taker routes all inter-maker messages. All communication strictly occurs over Tor.

For more details on the protocol and market mechanisms, refer to the Coinswap Protocol Specification.

Run the apps

❗ Important

The project currently only compiles on Linux. Mac and Windows are not supported yet. To compile on Mac or Windows, consider using virtual machines.

Dependencies

Ensure you have the following dependency installed before compiling.

sudo apt install build-essential automake libtool

The project also requires working rust and cargo installation to compile. Precompile binaries will be available soon. Cargo can be installed from here.

Build and Run the Apps

git clone https://github.com/citadel-tech/coinswap.git
cd coinswap
cargo build

After compilation you will get the binaries in the ./target/debug folder.

Currently, it is required to run the apps from the project root dirtectory only. This can be done by following commands.

./target/debug/makerd --help
./target/debug/maker-cli --help
./target/debug/taker --help

The apps also requires a fully synced, non-prunded bitcoind node with RPC access on Testnet4 with -txindex enabled.

An example bitcoin.conf with the required and other optional flags:

testnet4=1 #Required
server=1
txindex=1 #Required
rpcuser=user
rpcpassword=password
blockfilterindex=1 #This makes wallet sync faster
daemon=1

Apps overview

The apps can be used to run both the swap maker server and the taker client. The maker server is suitable to run inside a full node, or always online system. Although shutting down the server, and using it intermittently will also work.

makerd: The backend server daemon. This requires continuous uptime and connection to live bitcoin core RPC. App demo here

maker-cli: The RPC controler of the server deamon. This can be used to manage the server, access internal wallet, see swap statistics, etc. App demo here

taker: The swap client app. This acts as a regular bitcoin wallet with swap capability. App demo here

❗ Important

Once the makerd server setup is complete, always stop the server with maker-cli stop. Avoid using ctr+c to ensure wallet data integrity.

[Dev Mode] Checkout the tests

Extensive functional testing to simulate various edge cases of the protocol, is covered. The functional tests spawns a toy marketplace in Bitcoin regetst and plays out various protocol situation. Functional test logs are a good way to look at simulations of various edge cases in the protocol, and how the taker and makers recover from failed swaps.

The bitcoin binary used for testing is included here.

💡 Tip

Replace the bitcoind binary to run the tests with your custom bitcoind build.

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.

Run all the functional tests and see the logs:

$ cargo test --features=integration-test -- --nocapture

A rust based TestFramework (Inspired from the Bitcoin Core testframeowrk) has been designed to easily spawn the test situations, with many makers and takers. For example checkout the simple standard_swap module to see how to simulate a simple swap case programatically.

The functional tests is a good place for potential contributors to start tinkering and gathering context.

Contributing

The project is under active development by developers at Citadel Tech. 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 TODOs in the codebase to find in-line marked code todos and smaller improvements.

Setting Up Git Hooks

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

Community

The dev community lurks here.

Dev discussions predominantly happen via FOSS best practices, and by using Github as the major community forum.

The Issues, PRs and Discussions are where all the hard lifting happening.