Ride-The-Lightning-RTL/README.md

168 lines
6.9 KiB
Markdown
Raw Normal View History

2019-02-18 15:25:33 +01:00
## Ride The Lightning (RTL)
![](screenshots/RTL_Home.png)
2019-01-28 01:31:32 +01:00
<a href="https://snyk.io/test/github/ShahanaFarooqui/RTL"><img src="https://snyk.io/test/github/ShahanaFarooqui/RTL/badge.svg" alt="Known Vulnerabilities" data-canonical-src="https://snyk.io/test/github/ShahanaFarooqui/RTL" style="max-width:100%;"></a>
2019-02-22 01:07:38 +01:00
[![license](https://img.shields.io/github/license/DAVFoundation/captain-n3m0.svg?style=flat-square)](https://github.com/DAVFoundation/captain-n3m0/blob/master/LICENSE)
2019-04-04 12:05:27 +02:00
### Stable Release: v0.2.16
2019-02-21 01:34:30 +01:00
2019-04-14 01:52:17 +02:00
**Intro** -- [Application Features](docs/Application_features.md) -- [Road Map](docs/Roadmap.md) -- [LND API Coverage](docs/LNDAPICoverage.md) -- [Application Configurations](docs/Application_configurations)
2018-11-17 18:17:12 +01:00
2019-02-17 02:20:38 +01:00
* [Introduction](#intro)
2019-02-18 20:06:51 +01:00
* [Architecture](#arch)
2019-02-17 02:29:56 +01:00
* [Prerequisites](#prereq)
* [Installation](#install)
* [Prep For Execution](#prep)
* [Start The Server](#start)
* [Access The Application](#access)
* [Troubleshooting](#trouble)
### <a name="intro"></a>Introduction
2019-02-18 16:42:43 +01:00
RTL is a full function, device agnostic web user interface for Lightning Network Daemon, to help manage lightning node operations.
2019-02-18 15:51:58 +01:00
Lightning Network Daemon is an implementation of Lightning Network BOLT protocol by [Lightning Labs](https://lightning.engineering/).
2018-09-15 03:32:18 +02:00
2019-02-25 00:26:39 +01:00
Pre-requisite for running RTL is a functioning and synced LND node. You can setup your own node, by following the below guides:
* Windows/Mac users can follow Pierre Rochard's [Node Launcher](https://github.com/lightning-power-users/node-launcher)
* Linux or Raspberry Pi users can follow Stadicus's [guide](https://github.com/Stadicus/guides/blob/master/raspibolt/README.md)
2018-09-15 03:32:18 +02:00
2019-02-18 15:51:58 +01:00
RTL source code is available at this [repo](https://github.com/ShahanaFarooqui/RTLFullApplication)
2018-09-15 03:32:18 +02:00
2019-02-18 15:51:58 +01:00
For detailed screenshots and UI operation guide you can visit our [medium post](https://medium.com/@suheb.khan/how-to-ride-the-lightning-447af999dcd2)
2019-01-01 00:05:55 +01:00
2019-03-02 00:43:40 +01:00
RTL is already available on:
* [RaspiBlitz](https://github.com/rootzoll/raspiblitz)
* [Nodl](https://www.nodl.it/)
* [BTCPayserver](https://github.com/btcpayserver/btcpayserver-docker)
2019-03-03 04:43:12 +01:00
Docker Image: https://hub.docker.com/r/shahanafarooqui/rtl
2019-02-18 20:06:51 +01:00
### <a name="arch"></a>Architecture
2019-02-18 20:13:24 +01:00
![](screenshots/RTL_Arch.png)
2019-02-18 20:06:51 +01:00
2019-02-17 02:29:56 +01:00
### <a name="prereq"></a>Prerequisites
2019-02-25 00:26:39 +01:00
* Functioning and synced LND lightning node.
* Node.js, which can be downloaded [here](https://nodejs.org/en/download/)
* Recommended Browsers: Chrome, Firefox, MS Edge
2018-09-16 05:27:11 +02:00
2019-02-17 02:29:56 +01:00
### <a name="install"></a>Installation
2018-11-18 15:03:14 +01:00
#### First time setup
2019-02-25 00:43:45 +01:00
* Fetch sources from the RTL git repository, by executing the below on the command prompt:
2019-02-25 00:44:26 +01:00
2018-10-08 00:13:14 +02:00
`$ git clone https://github.com/ShahanaFarooqui/RTL.git`
2019-02-25 00:43:45 +01:00
* Change directory to RTL folder:
2019-02-25 00:44:26 +01:00
2018-10-08 00:13:14 +02:00
`$ cd RTL`
2019-02-25 00:43:45 +01:00
* Fetch the dependencies and build the application by running:
2019-02-25 00:44:26 +01:00
2018-10-08 00:13:14 +02:00
`$ npm install`
2018-09-15 03:32:18 +02:00
2019-02-25 00:43:45 +01:00
#### Or: Update existing build
2019-02-17 22:58:37 +01:00
```
2019-02-17 23:05:40 +01:00
$ cd RTL
2019-02-17 22:58:37 +01:00
$ git reset --hard HEAD
$ git clean -f -d
$ git pull
$ npm install
```
2019-02-17 02:29:56 +01:00
### <a name="prep"></a>Prep for Execution
2019-02-25 00:43:45 +01:00
RTL requires its own config file `RTL.conf`, to start the server and provide user authentication on the app.
2018-09-15 03:37:04 +02:00
2019-02-25 00:12:10 +01:00
* Rename `sample-RTL.conf` file to `RTL.conf`.
* Locate the complete path of the readable macroon file (admin.macroon) on your node and the lnd.conf file.
2019-02-25 00:43:45 +01:00
* Modify the `RTL.conf` file per the example file below
2019-02-21 02:55:12 +01:00
2019-02-25 00:43:45 +01:00
Example RTL.conf:
2019-01-01 17:26:51 +01:00
```
[Authentication]
2019-02-21 02:55:12 +01:00
macaroonPath=C:\Users\<user>\AppData\Local\Lnd\data\chain\bitcoin\testnet
nodeAuthType=CUSTOM
lndConfigPath=C:\Users\<user>\AppData\Local\Lnd\lnd.conf
rtlPass=***
[SSO]
rtlSSO=0
rtlCookiePath=C:\RTL\cookies\auth.cookie
logoutRedirectLink=/login
2019-01-01 17:26:51 +01:00
[Settings]
flgSidenavOpened=true
flgSidenavPinned=true
menu=Vertical
menuType=Regular
theme=dark-blue
satsToBTC=false
2019-02-21 02:55:12 +01:00
lndServerUrl=https://192.168.0.0:8080/v1
bitcoindConfigPath=
enableLogging=false
port=3000
2019-01-01 17:26:51 +01:00
```
2019-02-25 00:12:10 +01:00
For details on all the configuration options refer to [this page](https://github.com/ShahanaFarooqui/RTL/blob/master/Application_configurations).
2019-01-01 17:26:51 +01:00
#### User Authentication on RTL
2019-02-25 00:23:38 +01:00
RTL requires the user to be authenticated by the application first, before allowing access to LND functions.
2019-01-01 17:26:51 +01:00
There are two options to configure authentication on RTL, depending on the `nodeAuthtype` value provided in RTL.conf.
2018-10-08 00:21:45 +02:00
2019-02-25 00:32:28 +01:00
* Option 1: `nodeAuthType=DEFAULT`; Password provided in lnd.conf for the rpc setting for bitcoind will be used for authentication.
* Option 2: `nodeAuthType=CUSTOM`; Specific password must be provided in RTL.conf (in plain text) for authentication. Password should be set with `rtlPass=<user defined>` in the [Authentication] section of RTL.conf
2018-10-08 00:21:45 +02:00
2019-02-17 02:29:56 +01:00
### <a name="start"></a>Start the Server
2019-01-01 17:26:51 +01:00
Run the following command:
2018-10-08 00:21:45 +02:00
2019-02-25 00:16:11 +01:00
`$ node rtl`
2018-09-15 03:32:18 +02:00
If the server started successfully, you should get the below output on the console:
2019-02-25 00:16:11 +01:00
`$ Server is up and running, please open the UI at http://localhost:3000`
2018-09-15 03:32:18 +02:00
2019-02-25 00:23:38 +01:00
#### Optional: Running RTL as a service (Rpi or Linux platform users)
In case you are running a headless Rpi or a Linux node, you can configure RTL as a service.
2018-10-08 00:20:31 +02:00
2018-10-08 00:29:02 +02:00
* Create RTL systemd unit and with the following content. Save and exit.
2018-10-10 01:22:28 +02:00
```bash
# Raspibolt RTL: systemd unit for RTL
# /etc/systemd/system/RTL.service
2018-10-08 00:29:02 +02:00
[Unit]
Description=RTL daemon
Wants=lnd.service
2018-10-08 00:31:41 +02:00
After=lnd.service
2018-10-08 00:29:50 +02:00
2018-10-08 00:29:02 +02:00
[Service]
2019-02-25 00:12:10 +01:00
ExecStart=/usr/bin/node <Full path of the RTL folder>/rtl
2018-10-10 01:23:35 +02:00
User=<user>
2018-10-08 00:29:02 +02:00
Restart=always
TimeoutSec=120
RestartSec=30
[Install]
WantedBy=multi-user.target
2018-10-10 01:22:28 +02:00
```
2018-10-08 00:39:30 +02:00
2018-10-08 00:35:48 +02:00
* enable and start RTL
2019-02-17 22:58:37 +01:00
```
$ sudo systemctl enable RTL
$ sudo systemctl start RTL
```
2018-10-08 00:35:48 +02:00
* montior the RTL log file in realtime(exit with Ctrl-C)
2018-10-08 00:36:37 +02:00
2019-01-10 16:27:13 +01:00
`$ sudo journalctl -f -u RTL`
2018-10-08 00:35:48 +02:00
2019-02-17 02:29:56 +01:00
### <a name="access"></a>Accessing the Application
2019-03-22 22:16:26 +01:00
You can access the application in multiple setups (Please make note of the 4th exception):
2019-03-03 22:07:14 +01:00
1. Same device as the server:
2018-09-16 05:21:12 +02:00
Open your browser at the following address: http://localhost:3000 to access the RTL application.
2018-09-28 03:25:15 +02:00
2019-03-22 22:16:26 +01:00
2. Remotely from another device on the same local network (home network) as the node(RTL server+LND running on the same device):
2019-02-25 00:12:10 +01:00
* Ensure that the if a firewall running on your node, it allows access on port 3000 (or the custom port configured for RTL).
* Determine the IP address of your node to access the application.
2018-09-28 03:39:09 +02:00
E.g. if the IP address of your node is 192.168.0.15 then open your browser at the following address: http://192.168.0.15:3000 to access RTL.
2019-01-01 00:05:55 +01:00
2019-04-14 01:38:32 +02:00
3. Config tweaks for running RTL server and LND on separate devices on the same network can be found [here](docs/RTL_setups.md).
2019-03-22 22:16:26 +01:00
2019-03-30 19:51:30 +01:00
4. Any Other setup: **Please be advised, if you are accessing your node remotely via RTL, its critical to encrypt the communication via use of https. You can use solutions like nginx and letsencrypt or TOR to setup secure access for RTL.**
2019-04-14 01:35:59 +02:00
- Sample SSL setup guide can be found [here](docs/RTL_SSL_setup.md)
- (For advanced users) A sample SSL guide to serve remote access over an encrypted Tor connection can be found [here](docs/RTL_TOR_setup.md)
2019-03-03 22:02:52 +01:00
2019-02-17 02:29:56 +01:00
### <a name="trouble"></a>Troubleshooting
2019-02-24 00:11:44 +01:00
In case you are running into issues with the application or if you have feedback, feel free to open issues on our github repo.
2019-03-22 01:04:41 +01:00
You can also reach out to us via twitter DM on [@Sauby_k](https://twitter.com/sauby_k) or [@RTL_App](https://twitter.com/RTL_App). Thanks for your interest.