diff --git a/.gitignore b/.gitignore index 348131c1..d1abb459 100644 --- a/.gitignore +++ b/.gitignore @@ -2,4 +2,5 @@ __pycache__ db.sqlite3 lndg/settings.py frontend -node_modules \ No newline at end of file +node_modules +lndg-admin.txt \ No newline at end of file diff --git a/README.md b/README.md index d3eca066..e53cedbd 100644 --- a/README.md +++ b/README.md @@ -8,8 +8,11 @@ Start by choosing one of the following installation methods: ### Build and deploy 1. Clone respository `git clone https://github.com/cryptosharks131/lndg.git` 2. Change directory into the repo `cd lndg` -3. Customize `docker-compose.yaml` if you like and then build/deploy your docker image: `docker-compose up -d` -4. LNDg should now be available on port `8889` +3. Initialize db and admin backup `touch db.sqlite3 && touch lndg-admin.txt` +4. Update `docker-compose.yaml` if you are a non-root user and then build/deploy your docker image: `docker-compose up -d` +5. LNDg should now be available on port `8889` +6. Open and copy the password from output file: `nano lndg-admin.txt` +7. Use the password from the output file and the username `lndg-admin` to login ### Updating ``` @@ -18,16 +21,12 @@ docker-compose build --no-cache docker-compose up -d ``` -### Notes -1. Unless you save your `db.sqlite3` file before destroying your container, this data will be lost and rebuilt when making a new container. However, some data such as rebalances from previous containers cannot be rebuilt. -2. You can make this file persist by initializing it first locally `touch /root/lndg/db.sqlite3` and then mapping it locally in your docker-compose file under the volumes. `/root/lndg/db.sqlite3:/lndg/db.sqlite3:rw` - ## Umbrel Installation ### Build and deploy 1. Log into your umbrel via ssh 2. Clone respository `git clone https://github.com/cryptosharks131/lndg.git` 3. Change directory `cd lndg` -4. Initialize the database file `touch db.sqlite3` +4. Initialize db and admin backup `touch db.sqlite3 && touch lndg-admin.txt` 5. Copy and replace the contents of the docker-compose.yaml with the below: `nano docker-compose.yaml` ``` services: @@ -36,10 +35,11 @@ services: volumes: - /home/umbrel/umbrel/lnd:/root/.lnd:ro - /home/umbrel/lndg/db.sqlite3:/lndg/db.sqlite3:rw + - /home/umbrel/lndg/lndg-admin.txt:/lndg/lndg-admin.txt:rw command: - sh - -c - - python initialize.py -net 'mainnet' -server '10.21.21.9:10009' -d && python manage.py migrate && python manage.py collectstatic --no-input && supervisord && python manage.py runserver 0.0.0.0:8000 + - python initialize.py -net 'mainnet' -server '10.21.21.9:10009' -d && supervisord && python manage.py runserver 0.0.0.0:8000 ports: - 8889:8000 networks: @@ -49,6 +49,8 @@ networks: ``` 5. Deploy your docker image: `docker-compose up -d` 6. You can now access LNDg via your browser on port 8889: `http://umbrel.local:8889` +7. Open and copy the password from output file: `nano lndg-admin.txt` +8. Use the password from the output file and the username `lndg-admin` to login ### Updating ``` @@ -65,9 +67,10 @@ docker-compose up -d 4. Setup a python3 virtual environment `virtualenv -p python3 .venv` 5. Install required dependencies `.venv/bin/pip install -r requirements.txt` 6. Initialize some settings for your django site (see notes below) `.venv/bin/python initialize.py` -7. Migrate all database objects `.venv/bin/python manage.py migrate` +7. The initial login user is `lndg-admin` and the password is output here: `lndg-admin.txt` 8. Generate some initial data for your dashboard `.venv/bin/python jobs.py` 9. Run the server via a python development server `.venv/bin/python manage.py runserver 0.0.0.0:8889` +Tip: If you plan to only use the development server, you will need to setup whitenoise (see note below). ### Step 2 - Setup Backend Data, Automated Rebalancing and HTLC Stream Data The files `jobs.py`, `rebalancer.py` and `htlc_stream.py` inside lndg/gui/ serve to update the backend database with the most up to date information, rebalance any channels based on your lndg dashboard settings and to listen for any failure events in your htlc stream. A refresh interval of at least 10-20 seconds is recommended for the `jobs.py` and `rebalancer.py` files for the best user experience. @@ -84,11 +87,21 @@ Recommend Setup With Supervisord or Systemd Alternatively, you may also make your own task for these files with your preferred tool (task scheduler/cronjob/etc). +### Updating +1. Make sure you are in the lndg folder `cd lndg` +2. Pull the new files `git pull` +3. Migrate any database changes `.venv/bin/python manage.py migrate` + +### Nginx Webserver +If you would like to serve the dashboard at all times, it is recommended to setup a proper production webserver to host the site. +A bash script has been included to help aide in the setup of a nginx webserver. `sudo bash nginx.sh` + ### Notes 1. If you are not using the default settings for LND or you would like to run a LND instance on a network other than `mainnet` you can use the correct flags in step 6 (see `initialize.py --help`) or you can edit the variables directly in `lndg/lndg/settings.py`. 2. Some systems have a hard time serving static files (docker/macOs) and installing whitenoise and configuring it can help solve this issue. You can use `initialize.py -wn` to setup whitenoise and install it with `.venv/bin/pip install whitenoise`. 3. If you want to recreate a settings file, delete it from `lndg/lndg/settings.py` and rerun. `initialize.py` -4. If you plan to run this site continuously, consider setting up a proper web server to host it (see Nginx below). +4. If you plan to run this site continuously, consider setting up a proper web server to host it (see Nginx below). +5. You can manage your login credentials from the admin page. Example: `lndg.local/lndg-admin` ### Setup lndg initialize.py options 1. `-ip` or `--nodeip` - Accepts only this host IP to serve the LNDg page - default: `*` @@ -96,18 +109,11 @@ Alternatively, you may also make your own task for these files with your preferr 3. `-net` or `--network` - Network LND will run over - default: `mainnet` 4. `-server` or `--rpcserver` - Server address to use for rpc communications with LND - default: `localhost:10009` 5. `-sd` or `--supervisord` - Setup supervisord to run jobs/rebalancer background processes - default: `False` -6. `-wn` or `--whitenoise` - Add whitenoise middleware (docker requirement for static files) - default: `False` -7. `-d` or `--docker` - Single option for docker container setup (supervisord + whitenoise) - default: `False` -8. `-dx` or `--debug` - Setup the django site in debug mode - default: `False` - -### Updating -1. Make sure you are in the lndg folder `cd lndg` -2. Pull the new files `git pull` -3. Migrate any database changes `.venv/bin/python manage.py migrate` - -### Nginx Webserver -If you would like to serve the dashboard at all times, it is recommended to setup a proper production webserver to host the site. -A bash script has been included to help aide in the setup of a nginx webserver. `sudo bash nginx.sh` +6. `-sdu` or `--sduser` - Configure supervisord with a non-root user - default: `root` +7. `-wn` or `--whitenoise` - Add whitenoise middleware (docker requirement for static files) - default: `False` +8. `-d` or `--docker` - Single option for docker container setup (supervisord + whitenoise) - default: `False` +9. `-dx` or `--debug` - Setup the django site in debug mode - default: `False` +10. `-pw` or `--adminpw` Setup a custom admin password - default: `Randomized` ## Key Features ### API Backend @@ -117,6 +123,12 @@ The following data can be accessed at the /api endpoint: ### Peer Reconnection LNDg will automatically try to resolve any channels that are seen as inactive, no more than every 3 minutes per peer. +### Suggests New Peers +LNDg will make suggestions for new peers to open channels to based on your node's successful routing history. + +### Suggests New Peers +LNDg will make suggestions for new peers to open channels to based on your node's successful routing history. + ### HTLC Failure Stream LNDg will listen for failure events in your htlc stream and record them to the dashboard when they occur. diff --git a/docker-compose.yaml b/docker-compose.yaml index dc83efd0..87d4cfba 100644 --- a/docker-compose.yaml +++ b/docker-compose.yaml @@ -3,9 +3,11 @@ services: build: . volumes: - /root/.lnd:/root/.lnd:ro + - /root/lndg/db.sqlite3:/lndg/db.sqlite3:rw + - /root/lndg/lndg-admin.txt:/lndg/lndg-admin.txt:rw command: - sh - -c - - python initialize.py -net 'mainnet' -server 'localhost:10009' -d && python manage.py migrate && python manage.py collectstatic --no-input && supervisord && python manage.py runserver 0.0.0.0:8000 + - python initialize.py -net 'mainnet' -server 'localhost:10009' -d && supervisord && python manage.py runserver 0.0.0.0:8000 ports: - 8889:8000 \ No newline at end of file diff --git a/gui/forms.py b/gui/forms.py index 63c6de28..cd568966 100644 --- a/gui/forms.py +++ b/gui/forms.py @@ -38,8 +38,7 @@ class CloseChannelForm(forms.Form): force = forms.BooleanField(widget=forms.CheckboxSelectMultiple, required=False) class ConnectPeerForm(forms.Form): - peer_pubkey = forms.CharField(label='peer_pubkey', max_length=66) - host = forms.CharField(label='host', max_length=120) + peer_id = forms.CharField(label='peer_pubkey', max_length=200) class AddInvoiceForm(forms.Form): value = forms.IntegerField(label='value') diff --git a/gui/serializers.py b/gui/serializers.py index 038de7e0..18652087 100644 --- a/gui/serializers.py +++ b/gui/serializers.py @@ -55,8 +55,7 @@ class Meta: exclude = [] class ConnectPeerSerializer(serializers.Serializer): - peer_pubkey = serializers.CharField(label='peer_pubkey', max_length=66) - host = serializers.CharField(label='host', max_length=120) + peer_id = serializers.CharField(label='peer_pubkey', max_length=200) class OpenChannelSerializer(serializers.Serializer): peer_pubkey = serializers.CharField(label='peer_pubkey', max_length=66) diff --git a/gui/templates/action_list.html b/gui/templates/action_list.html new file mode 100644 index 00000000..07eee150 --- /dev/null +++ b/gui/templates/action_list.html @@ -0,0 +1,66 @@ +{% extends "base.html" %} +{% block content %} +{% load humanize %} +{% if action_list %} +
Channel ID | +Peer Alias | +Capacity | +Outbound Liquidity | ++ | Inbound Liquidity | +Unsettled | +oRate | +oBase | +o7D | +i7D | +iRate | +iBase | +AR | +Action | +
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
{{ channel.chan_id }} | +{{ channel.alias }} | +{{ channel.capacity|intcomma }} | +{{ channel.local_balance|intcomma }} ({{ channel.outbound_percent }}%) | +{% if channel.inbound_percent == 0 %}{% elif channel.outbound_percent == 0 %}{% else %}{% endif %} |
+ {{ channel.remote_balance|intcomma }} ({{ channel.inbound_percent }}%) | +{{ channel.unsettled_balance|intcomma }} | +{{ channel.local_fee_rate|intcomma }} | +{{ channel.local_base_fee|intcomma }} | +{{ channel.o7D|intcomma }} M ({{ channel.routed_out_7day }}) | +{{ channel.i7D|intcomma }} M ({{ channel.routed_in_7day }}) | +{{ channel.remote_fee_rate|intcomma }} | +{{ channel.remote_base_fee|intcomma }} | ++ {% if channel.auto_rebalance == True %} + + {% else %} + + {% endif %} + | +{{ channel.output }} | +