A simple and private bitcoin exchange
Go to file
2022-08-03 14:24:30 -07:00
.github Create codeql-analysis.yml 2022-07-23 14:31:25 +00:00
api Fix linear determinate countdown timer bug when waiting for escrow 2022-08-03 14:24:30 -07:00
chat Fix signature verification error due to clock mismatch. Fix amount limits rounding. 2022-06-05 04:18:06 -07:00
control Fix do_accounting. Improve ProfileAdmin load time. 2022-07-03 10:39:40 -07:00
docker Fix default rpcuser and rpcpass LND dev stack values 2022-07-31 06:30:21 -07:00
docs Increase Max trade size to 4M, increase max range size from 5 to 8 2022-07-30 05:27:15 -07:00
frontend Enable Thai translation 2022-08-03 05:43:28 -07:00
robosats Enable warnings logging to console via envvar 2022-08-01 05:55:43 -07:00
.dockerignore Add .dockerignore. Fix profile button tooltip. 2022-06-20 11:48:42 -07:00
.editorconfig Initialize the Django project and write setup guide 2022-01-01 10:53:17 -08:00
.env-sample Add tor proxy setting to envvars 2022-08-03 14:21:02 -07:00
.gitignore Update and clean dependencies 2022-07-16 15:21:05 -07:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2022-07-23 14:50:31 +00:00
CONTRIBUTING.md Update CONTRIBUTING.md 2022-05-08 17:11:07 +00:00
docker-compose.yml functional, but chat does not send messages (it does receive) 2022-06-26 15:43:57 -07:00
Dockerfile Create django.yml 2022-07-13 13:28:24 -07:00
LICENSE Add concept for BTC <> Fiat p2p swap using Lightning. 2022-01-01 07:28:49 -08:00
manage.py Re-format all python code 2022-02-17 11:50:10 -08:00
README.md Rectify inspiration paragraph on README.md 2022-07-30 11:30:22 +00:00
requirements.txt Clean up and finish new adress validator method (#202) 2022-08-01 01:03:33 +00:00
setup.md Add details in frontend setup guide about css files (#143) 2022-05-18 21:57:08 +00:00

RoboSats - Buy and sell Satoshis Privately

Docker Image CI Frontend Build release AGPL-3.0 license Telegram

RoboSats is a simple and private way to exchange bitcoin for national currencies. Robosats simplifies the peer-to-peer user experience and uses lightning hold invoices to minimize custody and trust requirements. The deterministically generated avatars help users stick to best privacy practices.

Try it out!

Bitcoin Mainnet

Always use Tor Browser and .onion for best privacy. The Clearnet URL redirects to a third party Tor2web service. Your privacy cannot be guaranteed to be respected. Use clearnet only to check around the app, never use for trading!

How to use it

Short video-walktrough

https://user-images.githubusercontent.com/90936742/167310017-dc211a05-dd5e-4ef4-b93f-250f80bc5bca.mp4

Video tutorial by Ben from BTCsessions (YouTube) ROBOSATS - Buy and Sell Bitcoin With No ID (Youtube)

How it works

Alice wants to buy satoshis privately:

  1. Alice generates an avatar (AdequateAlice01) using her private random token.
  2. Alice stores safely the token in case she needs to recover AdequateAlice01 in the future.
  3. Alice makes a new order and locks a small hold invoice to publish it (maker bond).
  4. Bob wants to sell satoshis, sees Alice's order in the book and takes it.
  5. Bob scans a small hold invoice as his taker bond. The contract is final.
  6. Bob posts the traded satoshis with a hold invoice. While Alice submits her payout invoice.
  7. On a private chat, Bob tells Alice how to send him fiat.
  8. Alice pays Bob, then they confirm the fiat has been sent and received.
  9. Bob's trade hold invoice is charged and the satoshis are sent to Alice.
  10. Bob and Alice's bonds return automatically, since they complied by the rules.
  11. The bonds would be charged (lost) in case of unilateral cancellation or cheating (lost dispute).

Contribute to the Robotic Satoshis Open Source Project

Check out our Contribution Guide to find how you can make RoboSats great.

Developer Rewards

Check out the Developer Rewards Panel for tasks paid in Sats.

Inspiration

The concept of a simple custody-minimized lightning exchange with hold invoices is inspired in P2PLNBOT by @grunch

License

The Robotic Satoshis Open Source Project is released under the terms of the AGPL3.0 license. See LICENSE for more details.