c-lightning-REST to clnrest migration.
4.2 KiB
Directions for setting up RTL to connect with and manage multiple nodes
Caution: This feature is for advanced users, running multiple nodes.
A single server instance of RTL can now be used to connect with multiple nodes on the same network. Multi-Node configuration requires the following:
- In case of LND node implementation, update lnd.conf for the node to enable remote connections and restart LND
- Configure 'RTL-Config.json' with individual entries for each node
- Restart RTL
- Run RTL and switch nodes live via dropdown on the menubar
1. Update lnd.conf
This step is only required to configure the nodes, which will be remotely connected with RTL.
- A static IP address must be assigned to the device running LND
admin.macaroon
for this node must be transferred to the device on which you need to run RTL- Add this setting your lnd.conf file under the [Application Options] section:
restlisten=<ip address of the device running LND>:8080
- Restart LND
2. Configure 'RTL-Config.json'
- Rename the file
Sample-RTL-Config.json
toRTL-Config.json
located at./RTL
. - 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 - Set the
port
to the preferred port number over which to run RTL - Set the
defaultNodeIndex
to configure the default start up node at server restart dbDirectoryPath
should be set to the folder where RTL's database will be saved.SSO
section can be used for single-sign-on from applications like BTCPayserver. If using RTL as a stand-alone app to connect with the nodes, keep thertlSSO=0
and ignore the rest ofSSO
section.nodes
section is a json array, with each element of the array representing the specific parameters for the LND node to connect with.index
must be a number and start with 1. This number must be unique for each node in the array. For each element, two items need to be configured for each node on the network (macaroonPath
andlnServerUrl
).macaroonPath
should be set to the local path of the folder containingadmin.macaroon
file for each node. Each node must have a different folder for theadmin.macaroon
on the RTL server.swapMacaroonPath
should be set to the local path of the folder containingloop.macaroon
file for loop.boltzMacaroonPath
should be set to the local path of the folder containingadmin.macaroon
file for boltz swaps.lnServerUrl
must be set to the service url for LND/Core Lightining REST APIs for each node, with the unique ip address of the node hosting LND/Core Lightning e.g. https://192.168.0.1:8080 OR https://192.168.0.1:3001. In this case the ip address of the node hosting LND/Core Lightning is '192.168.0.1'swapServerUrl
must be set to the swap service url. e.g. https://127.0.0.1:8081.boltzServerUrl
must be set to the boltz service url. e.g. https://127.0.0.1:9003.configPath
andbitcoindConfigPath
are optional parameters which can be set only if the RTL is running locally on the same node. Else it can be set to "" or removed from the conf file all together.lnApiPassword
is mandatory if the ln implementation is ECL and configPath is missing. It is used to provide password for API authentication. It will be ignored in other ln implementations.runePath
is mandatory for CLN implementation. It should be set to the local path of the folder including filename containing rune value. This rune value in the file should be saved inLIGHTNING_RUNE="your-rune"
format.
3. Restart RTL
4. Run RTL and switch nodes in the UI
The application should be accessed, with the ip and port combination, as earlier. The user needs to enter the password set with the multiPass
variable to authenticate. Once authenticated, the application will load the node with index configured with defaultNodeIndex
. The other nodes configured with the file, can be accessed via the dropdown in the side menu.
Thats all for now. The application is currently designed for a simple setup to access and manage multiple nodes. More features like an advanced multi-node dashboard can be developed in the future, depending upon the interest from the community.