Skip to content
This repository has been archived by the owner on May 5, 2024. It is now read-only.

Latest commit

 

History

History
115 lines (87 loc) · 4.56 KB

README.md

File metadata and controls

115 lines (87 loc) · 4.56 KB

Risq - feasibility study on re-implementing bisq in rust

Bisq is a decentralized application that allows trading of Bitcoin and other digital assets via a peer-to-peer trading protocol. Currently a proposal is being discussed regarding a backwards incompatible upgrade to the trading protocol that would rely on trading partners using the BSQ coloured coin as collateral when trading. This and other improvements are being proposed to launch as Bisq v2. As this would likely require re-writing large parts of the application, the question has been put forward whether it might be worth starting from scratch rather than take on the legacy of the existing code base.

This repo represents a spike to investigate the feasibility and effort required to rewrite the parts of the app needed for interop with V1

Goals

to shed some light on the following questions

  • is an alternative implementation that is compatible with the live p2p network possible (ie. can java <-> rust processes communicate correctly via the protobuf based protocol)?
  • are there any significant technical advantages that can be gained from taking this approach (eg. less overall complexity, less risky dependencies, better dev workflow etc.)?
  • how high would the remaining effort be to achieve production readiness with an alternative implementation?
  • does it make sense as a strategic approach to write V2 from scratch vs adapt the existing code?

Setup

You need to install rust and tor

Eg for mac:

$ curl https://sh.rustup.rs -sSf | sh
$ brew install tor

To play around with the last version published from our release pipeline you can:

$ cargo install risq
$ risq help

(Read more about the pipeline setup here)

Or use the make commands for building / testing / running Eg:

$ make build-all

Demo

Once the project has been built with make build a binary will be under ./target/debug/risq

$ ./target/debug/risq help
USAGE:
risq [OPTIONS] <SUBCOMMAND>

FLAGS:
    -h, --help       Prints help information
    -V, --version    Prints version information

SUBCOMMANDS:
    daemon    Runs the risq p2p node [aliases: d]
    help      Prints this message or the help of the given subcommand(s)
    offers    Subcomand to interact with offers

You can see help for the individual subcommands via:

$ ./target/debug/risq help daemon
<omitted>

Run the daemon after starting tor:

$ make run-tor
$ ./target/debug/risq d

It will take a while to bootstrap the data from the seed node (currently no data is persisted so bootstrap must execute every time you start the daemon).

From a different console you can check that the api is running via:

$ curl localhost:7477/ping
pong

Or use the cli to get the open offers (once it's bootstraped)

$ ./target/debug/risq offers --market USD | wc -l
  56

Api

The api that the daemon exposes uses a graphql schema. You can read about the background of graphql here.

To access data you must send a POST request to /graphql with the query attached as a string in the request body:

curl --header "Content-Type:application/json" \
     -XPOST \
     --data '{ "query": "{ offers(market: \"btc_usd\") { id } }" }' \
     http://localhost:7477/graphql | jq

There is also a query explorer exposed under http://localhost:7477/graphiql that can help you when developing a query.

Limitations

As this is a proof of concept there are a number of limitations.

  • No data is persisted so bootstrap is required for each run.
  • Only 1 connection to a seed node is currently established. If the initial data sync fails then daemon will not bootstrap properly or be able to join the p2p network.
  • Not much effort has been made to make the output look pretty or be particularly usefull other than seeing that things are alive.

Node Checker

To build and run the node checker do the following:

make build-with-checker
./target/debug/risq check-node 5quyxpxheyvzmb2d.onion 8000

To be compatible with Nagios-like monitoring tools (icinga, sensu, etc.), it returns 0 on success (Ping - Pong succeeded), or 2 in case of any error (such as the trouble making a connection, sending ping or getting response from the host.)