2
0
mirror of https://github.com/Ride-The-Lightning/RTL synced 2024-11-09 13:10:44 +00:00
Go to file
Shahana Farooqui 4c43b4c4c3 peers & channels list error on LND unlock issue fix #245
peers & channels list error on LND unlock issue fix #245
2020-02-03 12:09:13 -05:00
.circleci Update version REGEX for release canditates 2020-01-22 10:19:55 -05:00
.github/ISSUE_TEMPLATE Update issue templates 2018-10-09 15:15:38 -04:00
angular peers & channels list error on LND unlock issue fix #245 2020-02-03 12:09:13 -05:00
controllers peers & channels list error on LND unlock issue fix #245 2020-02-03 12:09:13 -05:00
docker Added missing env 2020-01-21 17:04:26 -05:00
docs Update C-Lightning-setup.md 2020-02-02 18:01:07 -05:00
e2e Merging Angular pre-build code 2019-03-18 20:13:01 -04:00
product management Merging Angular pre-build code 2019-03-18 20:13:01 -04:00
routes Password reset page 2020-01-21 19:18:34 -05:00
screenshots Updated arch images 2020-02-02 17:59:40 -05:00
src peers & channels list error on LND unlock issue fix #245 2020-02-03 12:09:13 -05:00
_config.yml Set theme jekyll-theme-hacker 2019-01-10 21:23:06 -05:00
.DS_Store Help updated 2020-01-07 19:50:04 -05:00
.editorconfig Config Updates 2020-01-08 09:44:58 -05:00
.gitattributes Initial commit 2018-09-14 21:31:01 -04:00
.gitignore SSO auth bug fix 2020-01-22 21:18:58 -05:00
angular.json Angular 8 Update 2019-07-27 14:20:17 -04:00
app.js Removed loop 2020-01-09 08:29:40 -05:00
common.js peers & channels list error on LND unlock issue fix #245 2020-02-03 12:09:13 -05:00
connect.js SSO auth bug fix 2020-01-22 21:18:58 -05:00
Dockerfile Dependency updates 2020-01-11 16:54:41 -05:00
Dockerfile.arm32v7 Dependency updates 2020-01-11 16:54:41 -05:00
Dockerfile.arm64v8 Dependency updates 2020-01-11 16:54:41 -05:00
LICENSE Create LICENSE 2018-09-27 22:23:50 -04:00
package-lock.json peers & channels list error on LND unlock issue fix #245 2020-02-03 12:09:13 -05:00
package.json peers & channels list error on LND unlock issue fix #245 2020-02-03 12:09:13 -05:00
prebuild.js Merging Angular pre-build code 2019-03-18 20:13:01 -04:00
protractor.conf.js Merging Angular pre-build code 2019-03-18 20:13:01 -04:00
README.md Update README.md 2020-02-02 18:00:25 -05:00
rtl.js Removed loop 2020-01-09 08:29:40 -05:00
sample-RTL-Config.json Config Upgrade RC 2020-01-20 22:22:03 -05:00
tsconfig.json Peers 2019-09-07 17:31:32 -04:00
tslint.json Merging Angular pre-build code 2019-03-18 20:13:01 -04:00

Ride The Lightning (RTL)

Known Vulnerabilities license

Stable Release: v0.6.4

Intro -- Application Features -- Road Map -- LND API Coverage -- Application Configurations -- C-lightning

Introduction

RTL is a full function, device agnostic, web user interface to help manage lightning node operations. RTL is available on LND and C-Lightning implementations.

This page covers instructions for LND. For C-lightning, refer to this page.

Lightning Network Daemon(LND) is an implementation of Lightning Network BOLT protocol by Lightning Labs.

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
  • Linux or Raspberry Pi users can follow Stadicus's guide

For detailed screenshots and UI operation guide you can visit our medium post

RTL is available on the below platforms/services:

Docker Image: https://hub.docker.com/r/shahanafarooqui/rtl

Architecture

Prerequisites

  • Functioning and synced LND lightning node.
  • Node.js, which can be downloaded here
    • On Ubuntu, g++ is required to install the node-sass dependency. This is available in the build-essential package.
      • The Most recent versions of node.js might give errors while installing node-sass. Use node.js LTS version 8 or 10 as a solution.
  • Recommended Browsers: Chrome, Firefox, MS Edge

Installation

First time setup

  • Fetch sources from RTL git repository, by executing the below on the command prompt:

$ git clone https://github.com/Ride-The-Lightning/RTL.git

  • Change directory to RTL folder:

$ cd RTL

  • Fetch the production dependencies by running: $ npm install --only=prod

Or: Update existing dependencies

$ cd RTL
$ git reset --hard HEAD
$ git clean -f -d
$ git pull
$ npm install --only=prod

Prep for Execution

RTL requires its own config file RTL-Config.json, to start the server and provide user authentication on the app.

Advanced users can refer to this page, for config settings required to manage multiple nodes

  • Rename sample-RTL-Config.json file to RTL-Config.json.
  • Locate the complete path of the readable macroon file (admin.macroon) on your node and the lnd.conf file.
  • Modify the RTL-Config.json file per the example file below

Example RTL-Config.json:

{
  "multiPass": "password",
  "port": "3000",
  "defaultNodeIndex": 1,
  "SSO": {
    "rtlSSO": 0,
    "rtlCookiePath": "",
    "logoutRedirectLink": ""
  },
  "nodes": [
    {
      "index": 1,
      "lnNode": "LND Testnet",
      "lnImplementation": "LND",
      "Authentication": {
        "macaroonPath": "<Complete path of the folder containing admin.macaroon for the node # 1>",
        "configPath": "<Optional:Path of the lnd.conf if present locally or empty>"
      },
      "Settings": {
        "userPersona": "OPERATOR",
        "themeMode": "DAY",
        "themeColor": "PURPLE",
        "channelBackupPath": "C:\\RTL\\backup\\node-1",
        "bitcoindConfigPath": "<Optional: path of bitcoind.conf path if available locally>",
        "enableLogging": true,
        "fiatConversion": false,
        "lnServerUrl": "<Service url for LND REST APIs for node # 1 e.g. https://192.168.0.1:8080/v1"
      }
    }
  ]
}

For details on all the configuration options refer to this page.

User Authentication on RTL

RTL requires the user to be authenticated by the application first, before allowing access to LND functions. Specific password must be provided in RTL-Config.json (in plain text) for authentication. Password should be set with multiPass:<user defined> in the Authentication section of RTL-Config.json. Default initial password is password.

Start the Server

Run the following command:

$ node rtl

If the server started successfully, you should get the below output on the console:

$ Server is up and running, please open the UI at http://localhost:3000

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.

  • Create RTL systemd unit and with the following content. Save and exit.
# Raspibolt RTL: systemd unit for RTL
# /etc/systemd/system/RTL.service

[Unit]
Description=RTL daemon
Wants=lnd.service
After=lnd.service

[Service]
ExecStart=/usr/bin/node <Full path of the RTL folder>/rtl
User=<user>
Restart=always
TimeoutSec=120
RestartSec=30

[Install]
WantedBy=multi-user.target
  • enable and start RTL
$ sudo systemctl enable RTL
$ sudo systemctl start RTL
  • montior the RTL log file in realtime(exit with Ctrl-C)

$ sudo journalctl -f -u RTL

Accessing the Application

You can access the application in multiple setups (Please make note of the 4th exception):

  1. Same device as the server: Open your browser at the following address: http://localhost:3000 to access the RTL application.

  2. Remotely from another device on the same local network (home network) as the node(RTL server+LND running on the same device):

  • 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. 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.
  1. Config tweaks for running RTL server and LND on separate devices on the same network can be found here.

  2. 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.

  • Sample SSL setup guide can be found here
  • (For advanced users) A sample SSL guide to serve remote access over an encrypted Tor connection can be found here

Troubleshooting

In case you are running into issues with the application or if you have feedback, feel free to open issues on our github repo. You can also reach out to us via twitter DM on @Suheb__ or @RTL_App. Thanks for your interest.