15 releases (4 breaking)
0.4.1 | Nov 13, 2019 |
---|---|
0.4.0 | Nov 12, 2019 |
0.3.5 | Nov 8, 2019 |
0.3.0 | Oct 27, 2019 |
0.0.7 | Oct 23, 2019 |
#29 in #backward
25 downloads per month
435KB
11K
SLoC
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 wether it might be worth starting from scratch rather than take on the legecy 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 rediness 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 its 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 perticularly 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.)
Dependencies
~40–53MB
~1M SLoC