2022-01-01 18:53:17 +00:00
# Set up
2022-04-17 12:08:09 +00:00
*Attention: to use RoboSats you do not need to run the stack, simply visit the website and that's it! This setup guide is intended for developer contributors and platform operators.*
# Frontend Development Only
Running the full stack is not easy, since RoboSats needs of many services. However, contributing to the frontend development can be done with a minimal setup!
*Set up time ~10 min. Tested in Chromium and Firefox in Ubuntu.*
------------------------
0 - `git clone {robosats-project}`
1 - `cd robosats/frontend`
2022-04-20 19:32:41 +00:00
2 - `npm install`
2022-04-17 12:08:09 +00:00
2022-04-20 19:32:41 +00:00
3 - `npm run dev` (leave it running)
2022-04-17 12:08:09 +00:00
2022-04-20 19:32:41 +00:00
4 - On another terminal `npm install -g http-server`
2022-04-17 12:08:09 +00:00
2022-05-18 21:57:08 +00:00
5 - Then run `http-server "robosats/frontend/static/`
2022-04-17 12:08:09 +00:00
2022-04-20 19:32:41 +00:00
6 - Install [Requestly ](https://requestly.io/ ) extension in your browser, it's a lightweight proxy. We want to use it so our browser grabs our local `main.js` instead of the remote. There are many alternatives to Requestly (be aware that Requestly might not respect your privacy. Didn't research it).
2022-04-17 12:08:09 +00:00
2022-04-20 19:32:41 +00:00
7 - Pick a RoboSats backend to test the new frontend: e.g. "robosats.onion.moe", or "unsafe.testnet.robosats.com". You can also use the onion services also if you are using Brave or Tor Browser (untested!)
2022-05-18 21:57:08 +00:00
8 - Open Requestly extension and add a new redirect rule. Make "{robosats-site}/static/frontend/main.js" redirect to "127.0.0.1:8080/frontend/main.js" and save the changes.
2022-04-17 12:08:09 +00:00
-------------------
2022-04-17 21:17:52 +00:00
**You are ready to go!** Edit the frontend code in `/frontend/src/` to make the changes you want. Within a few seconds, the `npm run dev` process will pack the code into the local `main.js` . Visit your selected {robosats-site} and you will see your new awesome frontend! :)
2022-04-17 12:08:09 +00:00
2022-05-18 21:57:08 +00:00
Every time you save changes to files in `/frontend/src` you will be able to see them in your browser after a few seconds using force refresh (Ctrl+Shift+R).
If you need to edit CSS or other static files in `/frontend/static` , simply add them to Requestly in the same way.
i.e: index.css
Make "{robosats-site}/static/css/index.css" redirect to "127.0.0.1:8080/css/index.css"
2022-04-17 12:08:09 +00:00
# Full Stack Development
## The Easy Way: Docker-compose (-dev containers running on testnet)
*Set up time, anywhere between ~45 min and 1 full day (depending on experience, whether you have a copy of the testnet blockchain, etc). Tested in Ubuntu.
2022-02-08 11:41:03 +00:00
Spinning up docker for the first time
```
docker-compose build --no-cache
2022-08-12 16:29:27 +00:00
# Install LND python dependencies into local repository
docker run --mount type=bind,src=$(pwd),dst=/usr/src/robosats backend sh generate_grpc.sh
2022-02-08 11:41:03 +00:00
docker-compose up -d
2022-08-15 10:44:54 +00:00
docker exec -it django-dev python3 manage.py makemigrations api control chat
2022-02-09 19:45:11 +00:00
docker exec -it django-dev python3 manage.py migrate
docker exec -it django-dev python3 manage.py createsuperuser
2022-02-08 11:41:03 +00:00
docker-compose restart
```
2022-04-17 12:08:09 +00:00
Copy the `.env-sample` file into `.env` and check the environmental variables are right for your development.
2022-02-08 11:41:03 +00:00
2022-04-17 12:08:09 +00:00
**All set!**
Commands you will need to startup:
2022-02-17 02:45:18 +00:00
2022-04-17 12:08:09 +00:00
* Spinning up the docker orchestration:
2022-02-08 11:41:03 +00:00
`docker-compose up -d`
2022-04-17 12:08:09 +00:00
* Then monitor in a terminal the Django dev docker service
2022-02-08 11:41:03 +00:00
`docker attach django-dev`
2022-04-17 12:08:09 +00:00
* And the NPM dev docker service
2022-02-08 11:41:03 +00:00
`docker attach npm-dev`
2022-04-17 12:08:09 +00:00
* You could also just check all services logs
2022-02-10 19:28:59 +00:00
`docker-compose logs -f`
2022-04-17 12:08:09 +00:00
You will need these commands also often or eventually:
2022-02-09 19:45:11 +00:00
2022-04-17 12:08:09 +00:00
* Unlock or 'create' the lnd node
2022-02-09 19:45:11 +00:00
`docker exec -it lnd-dev lncli unlock`
2022-04-17 12:08:09 +00:00
* Create p2wkh addresses
2022-02-09 19:45:11 +00:00
`docker exec -it lnd-dev lncli --network=testnet newaddress p2wkh`
2022-04-17 12:08:09 +00:00
* Wallet balance
2022-02-09 19:45:11 +00:00
`docker exec -it lnd-dev lncli --network=testnet walletbalance`
2022-04-17 12:08:09 +00:00
* Connect to peer
2022-02-09 19:45:11 +00:00
`docker exec -it lnd-dev lncli --network=testnet connect node_id@ip:9735`
2022-04-17 12:08:09 +00:00
* Open channel
2022-02-09 19:45:11 +00:00
`docker exec -it lnd-dev lncli --network=testnet openchannel node_id --local_amt LOCAL_AMT --push_amt PUSH_AMT`
2022-02-08 11:41:03 +00:00
2022-08-12 16:29:27 +00:00
**RoboSats development site should be accessible on 127.0.0.1:8000**
2022-04-17 12:08:09 +00:00
## The harder way (deprecated)
Setting up the stack on your base system is not supported by this guide anymore. Without dockerization of all services there is a thin chance you manage to have the platform running in less than 2 full days of work. These are legacy instructions, avoid them.
### Django development environment
2022-01-01 18:53:17 +00:00
### Install Python and pip
`sudo apt install python3 python3 pip`
### Install virtual environments
2022-01-06 16:54:37 +00:00
```
pip install virtualenvwrapper
```
2022-01-01 18:53:17 +00:00
### Add to .bashrc
2022-01-01 23:58:44 +00:00
```
export WORKON_HOME=$HOME/.virtualenvs
2022-01-01 18:53:17 +00:00
export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3
export VIRTUALENVWRAPPER_VIRTUALENV_ARGS=' -p /usr/bin/python3 '
export PROJECT_HOME=$HOME/Devel
2022-01-01 23:58:44 +00:00
source /usr/local/bin/virtualenvwrapper.sh
```
2022-01-01 18:53:17 +00:00
### Reload startup file
`source ~/.bashrc`
### Create virtual environment
`mkvirtualenv robosats_env`
### Activate environment
`workon robosats_env`
### Install Django and Restframework
`pip3 install django djangorestframework`
2022-01-05 11:20:08 +00:00
## Install Django admin relational links
`pip install django-admin-relation-links`
2022-01-13 14:08:21 +00:00
## Install dependencies for websockets
Install Redis
`apt-get install redis-server`
Test redis-server
`redis-cli ping`
Install python dependencies
```
pip install channels
pip install django-redis
pip install channels-redis
```
2022-01-16 12:31:25 +00:00
## Install Celery for Django tasks
```
pip install celery
pip install django-celery-beat
pip install django-celery-results
```
Start up celery worker
`celery -A robosats worker --beat -l info -S django`
2022-01-13 11:07:20 +00:00
2022-01-16 12:31:25 +00:00
*Django 3.2.11 at the time of writting*
*Celery 5.2.3*
2022-01-01 23:58:44 +00:00
### Launch the local development node
```
python3 manage.py makemigrations
python3 manage.py migrate
python3 manage.py runserver
```
2022-01-10 18:47:16 +00:00
### Install other python dependencies
2022-01-02 15:19:49 +00:00
```
pip install robohash
2022-01-10 18:47:16 +00:00
pip install python-decouple
pip install ring
```
### Install LND python dependencies
```
cd api/lightning
pip install grpcio grpcio-tools googleapis-common-protos
git clone https://github.com/googleapis/googleapis.git
curl -o lightning.proto -s https://raw.githubusercontent.com/lightningnetwork/lnd/master/lnrpc/lightning.proto
python3 -m grpc_tools.protoc --proto_path=googleapis:. --python_out=. --grpc_python_out=. lightning.proto
2022-01-02 15:19:49 +00:00
```
2022-01-11 20:49:53 +00:00
We also use the *Invoices* and *Router* subservices for invoice validation and payment routing.
2022-01-10 23:27:48 +00:00
```
curl -o invoices.proto -s https://raw.githubusercontent.com/lightningnetwork/lnd/master/lnrpc/invoicesrpc/invoices.proto
python3 -m grpc_tools.protoc --proto_path=googleapis:. --python_out=. --grpc_python_out=. invoices.proto
2022-01-11 20:49:53 +00:00
curl -o router.proto -s https://raw.githubusercontent.com/lightningnetwork/lnd/master/lnrpc/routerrpc/router.proto
python3 -m grpc_tools.protoc --proto_path=googleapis:. --python_out=. --grpc_python_out=. router.proto
2022-01-10 23:27:48 +00:00
```
2022-01-11 01:02:06 +00:00
Relative imports are not working at the moment, so some editing is needed in
2022-01-11 20:49:53 +00:00
`api/lightning` files `lightning_pb2_grpc.py` , `invoices_pb2_grpc.py` , `invoices_pb2.py` , `router_pb2_grpc.py` and `router_pb2.py` .
2022-01-11 01:02:06 +00:00
2022-01-11 20:49:53 +00:00
For example in `lightning_pb2_grpc.py` , add "from . " :
2022-01-11 01:02:06 +00:00
`import lightning_pb2 as lightning__pb2`
to
`from . import lightning_pb2 as lightning__pb2`
2022-01-02 15:19:49 +00:00
2022-02-06 18:43:17 +00:00
Same for every other file.
Generated files can be automatically patched like this:
```
sed -i 's/^import .*_pb2 as/from . \0/' api/lightning/router_pb2.py
sed -i 's/^import .*_pb2 as/from . \0/' api/lightning/invoices_pb2.py
sed -i 's/^import .*_pb2 as/from . \0/' api/lightning/router_pb2_grpc.py
sed -i 's/^import .*_pb2 as/from . \0/' api/lightning/lightning_pb2_grpc.py
sed -i 's/^import .*_pb2 as/from . \0/' api/lightning/invoices_pb2_grpc.py
```
2022-01-11 20:49:53 +00:00
2022-01-01 23:58:44 +00:00
## React development environment
### Install npm
`sudo apt install npm`
2022-01-04 15:00:34 +00:00
npm packages we use
2022-01-01 23:58:44 +00:00
```
cd frontend
npm init -y
npm i webpack webpack-cli --save-dev
npm i @babel/core babel-loader @babel/preset -env @babel/preset -react --save-dev
npm i react react-dom --save-dev
npm install @material -ui/core
npm install @babel/plugin -proposal-class-properties
npm install react-router-dom@5.2.0
npm install @material -ui/icons
2022-01-02 21:41:22 +00:00
npm install material-ui-image
2022-01-04 15:00:34 +00:00
npm install @mui/system @emotion/react @emotion/styled
2022-01-09 14:07:05 +00:00
npm install react-native
npm install react-native-svg
npm install react-qr-code
2022-01-09 22:17:15 +00:00
npm install @mui/material
2022-01-13 19:22:54 +00:00
npm install websocket
2022-01-14 00:43:26 +00:00
npm install react-countdown
2022-01-14 12:00:53 +00:00
npm install @mui/icons -material
2022-01-14 21:40:54 +00:00
npm install @mui/x -data-grid
2022-01-27 14:40:14 +00:00
npm install react-responsive
2022-01-28 00:17:20 +00:00
npm install react-qr-reader
2022-01-01 23:58:44 +00:00
```
2022-01-11 20:49:53 +00:00
Note we are using mostly MaterialUI V5 (@mui/material) but Image loading from V4 (@material-ui/core) extentions (so both V4 and V5 are needed)
2022-01-01 23:58:44 +00:00
2022-02-01 19:43:33 +00:00
### Launch
2022-01-01 23:58:44 +00:00
from frontend/ directory
2022-01-30 15:18:03 +00:00
`npm run dev`
## Robosats background threads.
There is 3 processes that run asynchronously: two admin commands and a celery beat scheduler.
The celery worker will run the task of caching external API market prices and cleaning(deleting) the generated robots that were never used.
`celery -A robosats worker --beat -l debug -S django`
The admin commands are used to keep an eye on the state of LND hold invoices and check whether orders have expired
```
python3 manage.py follow_invoices
python3 manage.py clean_order
```
It might be best to set up system services to continuously run these background processes.
### Follow invoices admin command as system service
Create `/etc/systemd/system/follow_invoices.service` and edit with:
```
[Unit]
Description=RoboSats Follow LND Invoices
After=lnd.service
StartLimitIntervalSec=0
[Service]
WorkingDirectory=/home/< USER > /robosats/
StandardOutput=file:/home/< USER > /robosats/follow_invoices.log
StandardError=file:/home/< USER > /robosats/follow_invoices.log
Type=simple
Restart=always
RestartSec=1
User=< USER >
ExecStart=python3 manage.py follow_invoices
[Install]
WantedBy=multi-user.target
```
Then launch it with
```
systemctl start follow_invoices
systemctl enable follow_invoices
```
### Clean orders admin command as system service
Create `/etc/systemd/system/clean_orders.service` and edit with (replace < USER > for your username):
```
[Unit]
Description=RoboSats Clean Orders
After=lnd.service
StartLimitIntervalSec=0
[Service]
WorkingDirectory=/home/< USER > /robosats/
StandardOutput=file:/home/< USER > /robosats/clean_orders.log
StandardError=file:/home/< USER > /robosats/clean_orders.log
Type=simple
Restart=always
RestartSec=1
User=< USER >
ExecStart=python3 manage.py clean_orders
[Install]
WantedBy=multi-user.target
```
Then launch it with
```
systemctl start clean_orders
systemctl enable clean_orders
2022-04-17 12:08:09 +00:00
```