Folder Restructure

Folder Restructure
pull/700/head
Shahana Farooqui 3 years ago
parent abd22f1987
commit f133e9d256

@ -25,7 +25,7 @@
"index": "src/index.html",
"main": "src/main.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.app.json",
"tsConfig": "src/tsconfig.app.json",
"allowedCommonJsDependencies": [
"sha256",
"qrcode",
@ -97,8 +97,8 @@
"options": {
"main": "src/test.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.spec.json",
"karmaConfig": "karma.conf.js",
"tsConfig": "src/tsconfig.spec.json",
"karmaConfig": "src/karma.conf.js",
"assets": [
"src/assets"
],

File diff suppressed because one or more lines are too long

@ -13,6 +13,6 @@
<style>@font-face{font-family:Roboto;src:url(Roboto-Thin.dbd56bd3357dc3617fe5.woff2) format("woff2"),url(Roboto-Thin.e7f7c82374bd0ebef14b.woff) format("woff");font-weight:100;font-style:normal;}@font-face{font-family:Roboto;src:url(Roboto-ThinItalic.a8cef84f735ef887abdc.woff2) format("woff2"),url(Roboto-ThinItalic.5dd9349c940073834e9a.woff) format("woff");font-weight:100;font-style:italic;}@font-face{font-family:Roboto;src:url(Roboto-Light.c27d89ac77468ae18f28.woff2) format("woff2"),url(Roboto-Light.d923dfafc0c5183b59aa.woff) format("woff");font-weight:300;font-style:normal;}@font-face{font-family:Roboto;src:url(Roboto-LightItalic.506274c7228cf81cae4d.woff2) format("woff2"),url(Roboto-LightItalic.d4b8c137518d9d92bb28.woff) format("woff");font-weight:300;font-style:italic;}@font-face{font-family:Roboto;src:url(Roboto-Regular.64cfb66c866ea50cad47.woff2) format("woff2"),url(Roboto-Regular.e02e9d6ff5547f7e9962.woff) format("woff");font-weight:400;font-style:normal;}@font-face{font-family:Roboto;src:url(Roboto-RegularItalic.4dd2af1e8df532f41db8.woff2) format("woff2"),url(Roboto-RegularItalic.5ea38fff9eebef99c5df.woff) format("woff");font-weight:400;font-style:italic;}@font-face{font-family:Roboto;src:url(Roboto-Medium.1d3bced88509b0838984.woff2) format("woff2"),url(Roboto-Medium.092c6130df8fd2199888.woff) format("woff");font-weight:500;font-style:normal;}@font-face{font-family:Roboto;src:url(Roboto-MediumItalic.d620b8f53f75966fe42e.woff2) format("woff2"),url(Roboto-MediumItalic.18ff1628c628080166c1.woff) format("woff");font-weight:500;font-style:italic;}@font-face{font-family:Roboto;src:url(Roboto-Bold.92fbd4e93cf0a5dbebaa.woff2) format("woff2"),url(Roboto-Bold.73288d91c325e82a5b92.woff) format("woff");font-weight:700;font-style:normal;}@font-face{font-family:Roboto;src:url(Roboto-BoldItalic.5f600d98a73d800ae575.woff2) format("woff2"),url(Roboto-BoldItalic.6d89acbd21d7e3fbecb2.woff) format("woff");font-weight:700;font-style:italic;}@font-face{font-family:Roboto;src:url(Roboto-Black.41ed1105a6ebb8ffe34e.woff2) format("woff2"),url(Roboto-Black.937491dfcbe64ca9a9f1.woff) format("woff");font-weight:900;font-style:normal;}@font-face{font-family:Roboto;src:url(Roboto-BlackItalic.50ca4c51ebc27e7e7d2f.woff2) format("woff2"),url(Roboto-BlackItalic.2e1ee657996854c6f427.woff) format("woff");font-weight:900;font-style:italic;}html{width:100%;height:99%;line-height:1.5;overflow-x:hidden;font-family:Roboto,sans-serif!important;font-size:62.5%;}body{box-sizing:border-box;margin:0;}body{height:100%;overflow:hidden;}*{margin:0;padding:0;}</style><link rel="stylesheet" href="styles.3746732b097bd500162f.css" media="print" onload="this.media='all'"><noscript><link rel="stylesheet" href="styles.3746732b097bd500162f.css"></noscript></head>
<body>
<rtl-app></rtl-app>
<script src="runtime.2201f3a07375d009e274.js" defer></script><script src="polyfills.99f4d82f067fba7525c4.js" defer></script><script src="main.ea8467faf9a7262e7e9a.js" defer></script>
<script src="runtime.cce8d677d0457c3f742e.js" defer></script><script src="polyfills.99f4d82f067fba7525c4.js" defer></script><script src="main.ea8467faf9a7262e7e9a.js" defer></script>
</body></html>

@ -1 +0,0 @@
(()=>{"use strict";var e,r,t,o={},a={};function n(e){var r=a[e];if(void 0!==r)return r.exports;var t=a[e]={id:e,loaded:!1,exports:{}};return o[e].call(t.exports,t,t.exports,n),t.loaded=!0,t.exports}n.m=o,e=[],n.O=(r,t,o,a)=>{if(!t){var l=1/0;for(f=0;f<e.length;f++){for(var[t,o,a]=e[f],i=!0,d=0;d<t.length;d++)(!1&a||l>=a)&&Object.keys(n.O).every(e=>n.O[e](t[d]))?t.splice(d--,1):(i=!1,a<l&&(l=a));i&&(e.splice(f--,1),r=o())}return r}a=a||0;for(var f=e.length;f>0&&e[f-1][2]>a;f--)e[f]=e[f-1];e[f]=[t,o,a]},n.n=e=>{var r=e&&e.__esModule?()=>e.default:()=>e;return n.d(r,{a:r}),r},n.d=(e,r)=>{for(var t in r)n.o(r,t)&&!n.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:r[t]})},n.f={},n.e=e=>Promise.all(Object.keys(n.f).reduce((r,t)=>(n.f[t](e,r),r),[])),n.u=e=>e+"."+{432:"fff61848c87895e92d32",646:"a7fbcc7e2f4d061c3f2a",891:"f25072f21dff6868476a",958:"1cf4b84ed31a6dda6249"}[e]+".js",n.miniCssF=e=>"styles.3746732b097bd500162f.css",n.o=(e,r)=>Object.prototype.hasOwnProperty.call(e,r),r={},t="rtl:",n.l=(e,o,a,l)=>{if(r[e])r[e].push(o);else{var i,d;if(void 0!==a)for(var f=document.getElementsByTagName("script"),s=0;s<f.length;s++){var u=f[s];if(u.getAttribute("src")==e||u.getAttribute("data-webpack")==t+a){i=u;break}}i||(d=!0,(i=document.createElement("script")).charset="utf-8",i.timeout=120,n.nc&&i.setAttribute("nonce",n.nc),i.setAttribute("data-webpack",t+a),i.src=e),r[e]=[o];var c=(t,o)=>{i.onerror=i.onload=null,clearTimeout(p);var a=r[e];if(delete r[e],i.parentNode&&i.parentNode.removeChild(i),a&&a.forEach(e=>e(o)),t)return t(o)},p=setTimeout(c.bind(null,void 0,{type:"timeout",target:i}),12e4);i.onerror=c.bind(null,i.onerror),i.onload=c.bind(null,i.onload),d&&document.head.appendChild(i)}},n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),n.p="",(()=>{var e={666:0};n.f.j=(r,t)=>{var o=n.o(e,r)?e[r]:void 0;if(0!==o)if(o)t.push(o[2]);else if(666!=r){var a=new Promise((t,a)=>o=e[r]=[t,a]);t.push(o[2]=a);var l=n.p+n.u(r),i=new Error;n.l(l,t=>{if(n.o(e,r)&&(0!==(o=e[r])&&(e[r]=void 0),o)){var a=t&&("load"===t.type?"missing":t.type),l=t&&t.target&&t.target.src;i.message="Loading chunk "+r+" failed.\n("+a+": "+l+")",i.name="ChunkLoadError",i.type=a,i.request=l,o[1](i)}},"chunk-"+r,r)}else e[r]=0},n.O.j=r=>0===e[r];var r=(r,t)=>{var o,a,[l,i,d]=t,f=0;for(o in i)n.o(i,o)&&(n.m[o]=i[o]);if(d)var s=d(n);for(r&&r(t);f<l.length;f++)n.o(e,a=l[f])&&e[a]&&e[a][0](),e[l[f]]=0;return n.O(s)},t=self.webpackChunkrtl=self.webpackChunkrtl||[];t.forEach(r.bind(null,0)),t.push=r.bind(null,t.push.bind(t))})()})();

@ -0,0 +1 @@
(()=>{"use strict";var e,r,t,a={},o={};function n(e){var r=o[e];if(void 0!==r)return r.exports;var t=o[e]={id:e,loaded:!1,exports:{}};return a[e].call(t.exports,t,t.exports,n),t.loaded=!0,t.exports}n.m=a,e=[],n.O=(r,t,a,o)=>{if(!t){var l=1/0;for(f=0;f<e.length;f++){for(var[t,a,o]=e[f],d=!0,i=0;i<t.length;i++)(!1&o||l>=o)&&Object.keys(n.O).every(e=>n.O[e](t[i]))?t.splice(i--,1):(d=!1,o<l&&(l=o));d&&(e.splice(f--,1),r=a())}return r}o=o||0;for(var f=e.length;f>0&&e[f-1][2]>o;f--)e[f]=e[f-1];e[f]=[t,a,o]},n.n=e=>{var r=e&&e.__esModule?()=>e.default:()=>e;return n.d(r,{a:r}),r},n.d=(e,r)=>{for(var t in r)n.o(r,t)&&!n.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:r[t]})},n.f={},n.e=e=>Promise.all(Object.keys(n.f).reduce((r,t)=>(n.f[t](e,r),r),[])),n.u=e=>e+"."+{432:"dc39fd03b195e32f9eba",646:"a7fbcc7e2f4d061c3f2a",891:"f25072f21dff6868476a",958:"1cf4b84ed31a6dda6249"}[e]+".js",n.miniCssF=e=>"styles.3746732b097bd500162f.css",n.o=(e,r)=>Object.prototype.hasOwnProperty.call(e,r),r={},t="rtl:",n.l=(e,a,o,l)=>{if(r[e])r[e].push(a);else{var d,i;if(void 0!==o)for(var f=document.getElementsByTagName("script"),s=0;s<f.length;s++){var u=f[s];if(u.getAttribute("src")==e||u.getAttribute("data-webpack")==t+o){d=u;break}}d||(i=!0,(d=document.createElement("script")).charset="utf-8",d.timeout=120,n.nc&&d.setAttribute("nonce",n.nc),d.setAttribute("data-webpack",t+o),d.src=e),r[e]=[a];var c=(t,a)=>{d.onerror=d.onload=null,clearTimeout(p);var o=r[e];if(delete r[e],d.parentNode&&d.parentNode.removeChild(d),o&&o.forEach(e=>e(a)),t)return t(a)},p=setTimeout(c.bind(null,void 0,{type:"timeout",target:d}),12e4);d.onerror=c.bind(null,d.onerror),d.onload=c.bind(null,d.onload),i&&document.head.appendChild(d)}},n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),n.p="",(()=>{var e={666:0};n.f.j=(r,t)=>{var a=n.o(e,r)?e[r]:void 0;if(0!==a)if(a)t.push(a[2]);else if(666!=r){var o=new Promise((t,o)=>a=e[r]=[t,o]);t.push(a[2]=o);var l=n.p+n.u(r),d=new Error;n.l(l,t=>{if(n.o(e,r)&&(0!==(a=e[r])&&(e[r]=void 0),a)){var o=t&&("load"===t.type?"missing":t.type),l=t&&t.target&&t.target.src;d.message="Loading chunk "+r+" failed.\n("+o+": "+l+")",d.name="ChunkLoadError",d.type=o,d.request=l,a[1](d)}},"chunk-"+r,r)}else e[r]=0},n.O.j=r=>0===e[r];var r=(r,t)=>{var a,o,[l,d,i]=t,f=0;for(a in d)n.o(d,a)&&(n.m[a]=d[a]);if(i)var s=i(n);for(r&&r(t);f<l.length;f++)n.o(e,o=l[f])&&e[o]&&e[o][0](),e[l[f]]=0;return n.O(s)},t=self.webpackChunkrtl=self.webpackChunkrtl||[];t.forEach(r.bind(null,0)),t.push=r.bind(null,t.push.bind(t))})()})();

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};
var pendingInvoices = [];

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,6 +1,6 @@
var request = require('request-promise');
var fs = require('fs');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var swtch = require('./switch');
var options = {};

@ -1,7 +1,7 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var connect = require('../../connect');
var connect = require('../../routes/connect');
var options = {};
exports.getInfo = (req, res, next) => {

@ -1,5 +1,5 @@
var request = require("request-promise");
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var options = {};
exports.getGraphInfo = (req, res, next) => {

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,6 +1,6 @@
var request = require('request-promise');
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};
var num_max_events = 100;

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var atob = require('atob');
var logger = require('../shared/logger');
var options = {};

@ -2,7 +2,7 @@ var ini = require('ini');
var parseHocon = require('hocon-parser');
var fs = require('fs');
var logger = require('./logger');
var common = require('../../common');
var common = require('../../routes/common');
var request = require('request-promise');
var options = {};

@ -1,5 +1,5 @@
var common = require('../../common');
var connect = require('../../connect');
var common = require('../../routes/common');
var connect = require('../../routes/connect');
var logger = require('./logger');
const jwt = require("jsonwebtoken");
const otplib = require("otplib");

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('../shared/logger');
var options = {};

@ -1,5 +1,5 @@
var fs = require('fs');
var common = require('../../common');
var common = require('../../routes/common');
exports.info = (msgJSON, selNode = common.selectedNode) => {
const msgStr = '\r\nINFO: ' + msgJSON.fileName + ' => ' + msgJSON.msg;

@ -1,5 +1,5 @@
var request = require('request-promise');
var common = require('../../common');
var common = require('../../routes/common');
var logger = require('./logger');
var options = {};

@ -45,7 +45,7 @@ $ npm install --only=prod
```
### <a name="prep"></a>Prep for Execution
RTL requires its own config file `RTL-Config.json`, to start the server and provide user authentication on the app.
* Rename `sample-RTL-Config.json` file to `RTL-Config.json`.
* Copy the file `Sample-RTL-Config.json` from `./RTL/docs` to `./RTL` and rename it to `RTL-Config.json`.
* Locate the complete path of the readable `access.macaroon` from `cl-rest` on your node.
* Modify the RTL conf file per the example file below

@ -40,7 +40,7 @@ $ npm install --only=prod
```
### <a name="prep"></a>Prep for Execution
RTL requires its own config file `RTL-Config.json`, to start the server and provide user authentication on the app.
* Rename `sample-RTL-Config.json` file to `RTL-Config.json`.
* Copy the file `Sample-RTL-Config.json` from `./RTL/docs` to `./RTL` and rename it to `RTL-Config.json`.
* Locate the complete path of the readable `eclair.conf` for your node.
* Modify the RTL conf file per the example file below

@ -16,7 +16,7 @@ This step is only required to configure the nodes, which will be remotely connec
4. Restart LND
#### 2. Configure 'RTL-Config.json'
1. Rename the `sample-RTL-Config.json` on the root RTL location to `RTL-Config.json`
1. Copy the file `Sample-RTL-Config.json` from `./RTL/docs` to `./RTL` and rename it to `RTL-Config.json`
2. Set `multiPass` to the preferred password. This password will be used to authenticate the user for RTL. Once authenticated, the user will be able to access all the nodes configured in the json file
3. Set the `port` to the preferred port number over which to run RTL
4. Set the `defaultNodeIndex` to configure the default start up node at server restart

@ -1,10 +1,10 @@
## Ride The Lightning (RTL)
![](screenshots/RTL-LND-Dashboard.png)
![](../screenshots/RTL-LND-Dashboard.png)
<a href="https://snyk.io/test/github/Ride-The-Lightning/RTL"><img src="https://snyk.io/test/github/Ride-The-Lightning/RTL/badge.svg" alt="Known Vulnerabilities" data-canonical-src="https://snyk.io/test/github/Ride-The-Lightning/RTL" style="max-width:100%;"></a>
[![license](https://img.shields.io/github/license/DAVFoundation/captain-n3m0.svg?style=flat-square)](https://github.com/DAVFoundation/captain-n3m0/blob/master/LICENSE)
**Intro** -- [Application Features](docs/Application_features.md) -- [Road Map](docs/Roadmap.md) -- [Application Configurations](docs/Application_configurations) -- [C-Lightning](docs/C-Lightning-setup.md) -- [Eclair](docs/Eclair-setup.md) -- [Contribution](docs/Contributing.md)
**Intro** -- [Application Features](Application_features.md) -- [Road Map](Roadmap.md) -- [Application Configurations](Application_configurations) -- [C-Lightning](C-Lightning-setup.md) -- [Eclair](Eclair-setup.md) -- [Contribution](Contributing.md)
* [Introduction](#intro)
* [Architecture](#arch)
@ -19,8 +19,8 @@
RTL is a full function, device agnostic, web user interface to help manage lightning node operations.
RTL is available on [LND](https://github.com/lightningnetwork/lnd), [C-Lightning](https://github.com/ElementsProject/lightning) and [Eclair](https://github.com/ACINQ/eclair) implementations.
* C-Lightning users, refer to [this](docs/C-Lightning-setup.md) page for install instructions.
* Eclair users, refer to [this](docs/Eclair-setup.md) page for install instructions.
* C-Lightning users, refer to [this](C-Lightning-setup.md) page for install instructions.
* Eclair users, refer to [this](Eclair-setup.md) page for install instructions.
* LND users, follow the instructions below
Lightning Network Daemon(LND) is an implementation of Lightning Network BOLT protocol by [Lightning Labs](https://lightning.engineering/).
@ -41,7 +41,7 @@ RTL is available on the below platforms/services:
Docker Image: https://hub.docker.com/r/shahanafarooqui/rtl
### <a name="arch"></a>Architecture
![](screenshots/RTL-LND-Arch-2.png)
![](../screenshots/RTL-LND-Arch-2.png)
### <a name="prereq"></a>Prerequisites
* Functioning and synced LND lightning node.
@ -69,9 +69,9 @@ $ npm install --only=prod
### <a name="prep"></a>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](docs/Multi-Node-setup.md), for config settings required to manage multiple nodes*
*Advanced users can refer to [this page](Multi-Node-setup.md), for config settings required to manage multiple nodes*
* Rename `sample-RTL-Config.json` file to `RTL-Config.json`.
* Copy the file `Sample-RTL-Config.json` from `./RTL/docs` to `./RTL` and rename it 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
@ -114,7 +114,7 @@ Example RTL-Config.json:
]
}
```
For details on all the configuration options refer to [this page](./docs/Application_configurations).
For details on all the configuration options refer to [this page](./Application_configurations).
#### User Authentication on RTL
RTL requires the user to be authenticated by the application first, before allowing access to LND functions.
@ -172,11 +172,11 @@ Open your browser at the following address: http://localhost:3000 to access the
* 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.
3. Config tweaks for running RTL server and LND on separate devices on the same network can be found [here](docs/RTL_setups.md).
3. Config tweaks for running RTL server and LND on separate devices on the same network can be found [here](RTL_setups.md).
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.**
- 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)
- Sample SSL setup guide can be found [here](RTL_SSL_setup.md)
- (For advanced users) A sample SSL guide to serve remote access over an encrypted Tor connection can be found [here](RTL_TOR_setup.md)
### <a name="trouble"></a>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.

@ -7,6 +7,7 @@
"start": "ng serve --open",
"prebuild": "node ./src/prebuild",
"build": "ng analytics off && ng lint && ng build --configuration production",
"devbuild": "ng build --configuration production",
"serve": "ng serve",
"server": "nodemon ./rtl.js",
"test": "ng test",

@ -1,28 +0,0 @@
// Protractor configuration file, see link for more information
// https://github.com/angular/protractor/blob/master/lib/config.ts
const { SpecReporter } = require('jasmine-spec-reporter');
exports.config = {
allScriptsTimeout: 11000,
specs: [
'./e2e/**/*.e2e-spec.ts'
],
capabilities: {
'browserName': 'chrome'
},
directConnect: true,
baseUrl: 'http://localhost:4200/',
framework: 'jasmine',
jasmineNodeOpts: {
showColors: true,
defaultTimeoutInterval: 30000,
print: function() {}
},
onPrepare() {
require('ts-node').register({
project: 'e2e/tsconfig.e2e.json'
});
jasmine.getEnv().addReporter(new SpecReporter({ spec: { displayStacktrace: true } }));
}
};

@ -11,49 +11,46 @@ const apiLNDRoot = baseHref + "api/lnd/";
const apiCLRoot = baseHref + "api/cl/";
const apiECLRoot = baseHref + "api/ecl/";
const authenticateRoutes = require("./routes/shared/authenticate");
const RTLConfRoutes = require("./routes/shared/RTLConf");
const loopRoutes = require('./routes/shared/loop');
const boltzRoutes = require('./routes/shared/boltz');
const authenticateRoutes = require("./shared/authenticate");
const RTLConfRoutes = require("./shared/RTLConf");
const loopRoutes = require('./shared/loop');
const boltzRoutes = require('./shared/boltz');
const infoRoutes = require("./routes/lnd/getInfo");
const channelsRoutes = require("./routes/lnd/channels");
const channelsBackupRoutes = require("./routes/lnd/channelsBackup");
const peersRoutes = require("./routes/lnd/peers");
const feesRoutes = require("./routes/lnd/fees");
const balanceRoutes = require("./routes/lnd/balance");
const walletRoutes = require("./routes/lnd/wallet");
const graphRoutes = require("./routes/lnd/graph");
const newAddressRoutes = require("./routes/lnd/newAddress");
const transactionsRoutes = require("./routes/lnd/transactions");
const payReqRoutes = require("./routes/lnd/payReq");
const paymentsRoutes = require("./routes/lnd/payments");
const invoiceRoutes = require("./routes/lnd/invoices");
const switchRoutes = require("./routes/lnd/switch");
const messageRoutes = require("./routes/lnd/message");
const infoRoutes = require("./lnd/getInfo");
const channelsRoutes = require("./lnd/channels");
const channelsBackupRoutes = require("./lnd/channelsBackup");
const peersRoutes = require("./lnd/peers");
const feesRoutes = require("./lnd/fees");
const balanceRoutes = require("./lnd/balance");
const walletRoutes = require("./lnd/wallet");
const graphRoutes = require("./lnd/graph");
const newAddressRoutes = require("./lnd/newAddress");
const transactionsRoutes = require("./lnd/transactions");
const payReqRoutes = require("./lnd/payReq");
const paymentsRoutes = require("./lnd/payments");
const invoiceRoutes = require("./lnd/invoices");
const switchRoutes = require("./lnd/switch");
const messageRoutes = require("./lnd/message");
const infoCLRoutes = require("./routes/c-lightning/getInfo");
const feesCLRoutes = require("./routes/c-lightning/fees");
const balanceCLRoutes = require("./routes/c-lightning/balance");
const channelsCLRoutes = require("./routes/c-lightning/channels");
const invoicesCLRoutes = require("./routes/c-lightning/invoices");
const onChainCLRoutes = require("./routes/c-lightning/onchain");
const paymentsCLRoutes = require("./routes/c-lightning/payments");
const peersCLRoutes = require("./routes/c-lightning/peers");
const networkCLRoutes = require("./routes/c-lightning/network");
const messageCLRoutes = require("./routes/c-lightning/message");
const infoCLRoutes = require("./c-lightning/getInfo");
const feesCLRoutes = require("./c-lightning/fees");
const balanceCLRoutes = require("./c-lightning/balance");
const channelsCLRoutes = require("./c-lightning/channels");
const invoicesCLRoutes = require("./c-lightning/invoices");
const onChainCLRoutes = require("./c-lightning/onchain");
const paymentsCLRoutes = require("./c-lightning/payments");
const peersCLRoutes = require("./c-lightning/peers");
const networkCLRoutes = require("./c-lightning/network");
const messageCLRoutes = require("./c-lightning/message");
const infoECLRoutes = require("./routes/eclair/getInfo");
const feesECLRoutes = require("./routes/eclair/fees");
const channelsECLRoutes = require("./routes/eclair/channels");
const onChainECLRoutes = require("./routes/eclair/onchain");
const peersECLRoutes = require("./routes/eclair/peers");
const invoicesECLRoutes = require("./routes/eclair/invoices");
const paymentsECLRoutes = require("./routes/eclair/payments");
const networkECLRoutes = require("./routes/eclair/network");
const csurf = require("csurf");
const app = express();
const infoECLRoutes = require("./eclair/getInfo");
const feesECLRoutes = require("./eclair/fees");
const channelsECLRoutes = require("./eclair/channels");
const onChainECLRoutes = require("./eclair/onchain");
const peersECLRoutes = require("./eclair/peers");
const invoicesECLRoutes = require("./eclair/invoices");
const paymentsECLRoutes = require("./eclair/payments");
const networkECLRoutes = require("./eclair/network");
const app = express();
const csrfProtection = csurf({cookie: true});
@ -62,7 +59,7 @@ app.set('trust proxy', true);
app.use(cookieParser(common.secret_key));
app.use(bodyParser.json({limit: '25mb'}));
app.use(bodyParser.urlencoded({extended: false, limit: '25mb'}));
app.use(baseHref, express.static(path.join(__dirname, "angular")));
app.use(baseHref, express.static(path.join(__dirname, "..", "angular")));
app.use((req, res, next) => {
res.setHeader(
@ -123,7 +120,7 @@ app.use(apiECLRoot + "network", networkECLRoutes);
app.use((req, res, next) => {
res.cookie('XSRF-TOKEN', req.csrfToken());
res.sendFile(path.join(__dirname, "angular", "index.html"));
res.sendFile(path.join(__dirname, "..", "angular", "index.html"));
});
module.exports = app;

@ -5,7 +5,7 @@ var crypto = require('crypto');
var hash = crypto.createHash('sha256');
var common = require('./common');
var path = require('path');
var logger = require('./controllers/shared/logger');
var logger = require('../controllers/shared/logger');
var connect = {};
var errMsg = '';
var request = require('request-promise');
@ -84,7 +84,7 @@ connect.normalizePort = val => {
};
connect.replacePasswordWithHash = (multiPassHashed) => {
common.rtl_conf_file_path = process.env.RTL_CONFIG_PATH ? process.env.RTL_CONFIG_PATH : path.normalize(__dirname);
common.rtl_conf_file_path = process.env.RTL_CONFIG_PATH ? process.env.RTL_CONFIG_PATH : path.normalize(__dirname + '..');
try {
RTLConfFile = common.rtl_conf_file_path + common.path_separator + 'RTL-Config.json';
var config = JSON.parse(fs.readFileSync(RTLConfFile, 'utf-8'));
@ -551,7 +551,7 @@ connect.upgradeConfig = (confFileFullPath) => {
connect.setServerConfiguration = () => {
try {
common.rtl_conf_file_path = (process.env.RTL_CONFIG_PATH) ? process.env.RTL_CONFIG_PATH : path.normalize(__dirname);
common.rtl_conf_file_path = (process.env.RTL_CONFIG_PATH) ? process.env.RTL_CONFIG_PATH : path.normalize(__dirname + '/..');
confFileFullPath = common.rtl_conf_file_path + common.path_separator + 'RTL-Config.json';
if(!fs.existsSync(confFileFullPath)) {
connect.upgradeConfig(confFileFullPath);

@ -1,5 +1,5 @@
const jwt = require("jsonwebtoken");
var common = require('../../common');
var common = require('../../routes/common');
module.exports = (req, res, next) => {
try {

@ -1,9 +1,9 @@
#!/usr/bin/env node
const app = require("./app");
const common = require("./common");
const app = require("./routes/app");
const common = require("./routes/common");
const http = require("http");
var connect = require('./connect').setServerConfiguration(); //Do NOT Remove
var connect = require("./routes/connect").setServerConfiguration(); //Do NOT Remove
const onError = error => {
if (error.syscall !== "listen") {

@ -47,8 +47,6 @@ export class ECLChannelsTablesComponent implements OnInit, OnDestroy {
this.information = rtlStore.information;
this.peers = rtlStore.peers;
this.totalBalance = rtlStore.onchainBalance.total;
console.warn(this.numOfPendingChannels);
console.warn(rtlStore.channelsStatus.pending);
this.logger.info(rtlStore);
});
}

@ -0,0 +1,20 @@
/* To learn more about this file see: https://angular.io/config/tsconfig. */
{
"extends": "../tsconfig.json",
"compilerOptions": {
"baseUrl": "./",
"outDir": "../angular",
"types": ["node"],
"paths": {
"crypto": ["../node_modules/crypto-browserify"],
"stream": ["../node_modules/stream-browserify"]
}
},
"files": [
"./main.ts",
"./polyfills.ts"
],
"include": [
"./**/*.d.ts"
]
}

@ -1,18 +1,18 @@
/* To learn more about this file see: https://angular.io/config/tsconfig. */
{
"extends": "./tsconfig.json",
"extends": "../tsconfig.json",
"compilerOptions": {
"outDir": "./out-tsc/spec",
"outDir": "../out-tsc/spec",
"types": [
"jasmine"
]
},
"files": [
"src/test.ts",
"src/polyfills.ts"
"./test.ts",
"./polyfills.ts"
],
"include": [
"src/**/*.spec.ts",
"src/**/*.d.ts"
"./**/*.spec.ts",
"./**/*.d.ts"
]
}

@ -1,20 +0,0 @@
/* To learn more about this file see: https://angular.io/config/tsconfig. */
{
"extends": "./tsconfig.json",
"compilerOptions": {
"baseUrl": "./",
"outDir": "./angular",
"types": ["node"],
"paths": {
"crypto": ["node_modules/crypto-browserify"],
"stream": ["node_modules/stream-browserify"]
}
},
"files": [
"src/main.ts",
"src/polyfills.ts"
],
"include": [
"src/**/*.d.ts"
]
}
Loading…
Cancel
Save