2019-08-31 14:30:56 +02:00
|
|
|
lightningd-config -- Lightning daemon configuration file
|
|
|
|
========================================================
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
|
|
|
|
|
|
|
**~/.lightning/config**
|
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
|
|
|
|
2019-11-23 02:45:53 +01:00
|
|
|
When lightningd(8) starts up it usually reads a general configuration
|
|
|
|
file (default: **$HOME/.lightning/config**) then a network-specific
|
|
|
|
configuration file (default: **$HOME/.lightning/testnet/config**). This can
|
|
|
|
be changed: see *--conf* and *--lightning-dir*.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2019-11-23 02:45:53 +01:00
|
|
|
General configuration files are processed first, then network-specific
|
|
|
|
ones, then command line options: later options override earlier ones
|
|
|
|
except *addr* options and *log-level* with subsystems, which
|
|
|
|
accumulate.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2019-11-23 02:44:51 +01:00
|
|
|
*include * followed by a filename includes another configuration file at that
|
|
|
|
point, relative to the current configuration file.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
All these options are mirrored as commandline arguments to
|
|
|
|
lightningd(8), so *--foo* becomes simply *foo* in the configuration
|
|
|
|
file, and *--foo=bar* becomes *foo=bar* in the configuration file.
|
|
|
|
|
|
|
|
Blank lines and lines beginning with *\#* are ignored.
|
|
|
|
|
|
|
|
DEBUGGING
|
|
|
|
---------
|
|
|
|
|
|
|
|
*--help* will show you the defaults for many options; they vary with
|
|
|
|
network settings so you can specify *--network* before *--help* to see
|
|
|
|
the defaults for that network.
|
|
|
|
|
|
|
|
The lightning-listconfigs(7) command will output a valid configuration
|
|
|
|
file using the current settings.
|
|
|
|
|
|
|
|
OPTIONS
|
|
|
|
-------
|
|
|
|
|
|
|
|
### General options
|
|
|
|
|
|
|
|
**allow-deprecated-apis**=*BOOL*
|
|
|
|
Enable deprecated options, JSONRPC commands, fields, etc. It defaults to
|
|
|
|
*true*, but you should set it to *false* when testing to ensure that an
|
2021-10-24 11:44:56 +02:00
|
|
|
upgrade won't break your configuration.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**help**
|
|
|
|
Print help and exit. Not very useful inside a configuration file, but
|
2021-10-24 11:44:56 +02:00
|
|
|
fun to put in other's config files while their computer is unattended.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**version**
|
|
|
|
Print version and exit. Also useless inside a configuration file, but
|
2021-10-24 11:44:56 +02:00
|
|
|
putting this in someone's config file may convince them to read this man
|
2019-08-10 01:54:18 +02:00
|
|
|
page.
|
|
|
|
|
|
|
|
Bitcoin control options:
|
|
|
|
|
|
|
|
**network**=*NETWORK*
|
2020-10-15 12:54:59 +02:00
|
|
|
Select the network parameters (*bitcoin*, *testnet*, *signet*, or *regtest*).
|
2019-11-23 02:46:40 +01:00
|
|
|
This is not valid within the per-network configuration file.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2020-10-15 12:04:37 +02:00
|
|
|
**mainnet**
|
|
|
|
Alias for *network=bitcoin*.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**testnet**
|
|
|
|
Alias for *network=testnet*.
|
|
|
|
|
|
|
|
**signet**
|
|
|
|
Alias for *network=signet*.
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**bitcoin-cli**=*PATH* [plugin `bcli`]
|
2019-08-10 01:54:18 +02:00
|
|
|
The name of *bitcoin-cli* executable to run.
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**bitcoin-datadir**=*DIR* [plugin `bcli`]
|
2019-08-10 01:54:18 +02:00
|
|
|
*-datadir* argument to supply to bitcoin-cli(1).
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**bitcoin-rpcuser**=*USER* [plugin `bcli`]
|
2019-08-10 01:54:18 +02:00
|
|
|
The RPC username for talking to bitcoind(1).
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**bitcoin-rpcpassword**=*PASSWORD* [plugin `bcli`]
|
2019-08-10 01:54:18 +02:00
|
|
|
The RPC password for talking to bitcoind(1).
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**bitcoin-rpcconnect**=*HOST* [plugin `bcli`]
|
2019-08-10 01:54:18 +02:00
|
|
|
The bitcoind(1) RPC host to connect to.
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**bitcoin-rpcport**=*PORT* [plugin `bcli`]
|
2019-08-10 01:54:18 +02:00
|
|
|
The bitcoind(1) RPC port to connect to.
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**bitcoin-retry-timeout**=*SECONDS* [plugin `bcli`]
|
2019-08-10 01:54:18 +02:00
|
|
|
Number of seconds to keep trying a bitcoin-cli(1) command. If the
|
|
|
|
command keeps failing after this time, exit with a fatal error.
|
|
|
|
|
|
|
|
**rescan**=*BLOCKS*
|
|
|
|
Number of blocks to rescan from the current head, or absolute
|
|
|
|
blockheight if negative. This is only needed if something goes badly
|
|
|
|
wrong.
|
|
|
|
|
|
|
|
### Lightning daemon options
|
|
|
|
|
|
|
|
**lightning-dir**=*DIR*
|
|
|
|
Sets the working directory. All files (except *--conf* and
|
2019-11-23 02:46:40 +01:00
|
|
|
*--lightning-dir* on the command line) are relative to this. This
|
|
|
|
is only valid on the command-line, or in a configuration file specified
|
|
|
|
by *--conf*.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2020-02-04 01:14:13 +01:00
|
|
|
**subdaemon**=*SUBDAEMON*:*PATH*
|
|
|
|
Specifies an alternate subdaemon binary.
|
|
|
|
Current subdaemons are *channeld*, *closingd*,
|
|
|
|
*connectd*, *gossipd*, *hsmd*, *onchaind*, and *openingd*.
|
|
|
|
If the supplied path is relative the subdaemon binary is found in the
|
|
|
|
working directory. This option may be specified multiple times.
|
|
|
|
|
|
|
|
So, **subdaemon=hsmd:remote_signer** would use a
|
|
|
|
hypothetical remote signing proxy instead of the standard *lightning_hsmd*
|
|
|
|
binary.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**pid-file**=*PATH*
|
|
|
|
Specify pid file to write to.
|
|
|
|
|
2019-11-18 01:27:17 +01:00
|
|
|
**log-level**=*LEVEL*\[:*SUBSYSTEM*\]
|
2019-08-10 01:54:18 +02:00
|
|
|
What log level to print out: options are io, debug, info, unusual,
|
2019-11-18 01:27:17 +01:00
|
|
|
broken. If *SUBSYSTEM* is supplied, this sets the logging level
|
2021-12-25 20:06:31 +01:00
|
|
|
for any subsystem containing that string. This option may be specified multiple times.
|
|
|
|
Subsystems include:
|
2019-11-18 01:27:17 +01:00
|
|
|
|
|
|
|
* *lightningd*: The main lightning daemon
|
|
|
|
* *database*: The database subsystem
|
|
|
|
* *wallet*: The wallet subsystem
|
|
|
|
* *gossipd*: The gossip daemon
|
|
|
|
* *plugin-manager*: The plugin subsystem
|
|
|
|
* *plugin-P*: Each plugin, P = plugin path without directory
|
|
|
|
* *hsmd*: The secret-holding daemon
|
|
|
|
* *connectd*: The network connection daemon
|
2019-11-18 01:27:18 +01:00
|
|
|
* *jsonrpc#FD*: Each JSONRPC connection, FD = file descriptor number
|
2019-11-18 01:27:17 +01:00
|
|
|
|
2019-11-18 01:27:18 +01:00
|
|
|
|
|
|
|
The following subsystems exist for each channel, where N is an incrementing
|
2019-11-18 01:27:17 +01:00
|
|
|
internal integer id assigned for the lifetime of the channel:
|
2019-11-18 01:27:18 +01:00
|
|
|
* *openingd-chan#N*: Each opening / idling daemon
|
|
|
|
* *channeld-chan#N*: Each channel management daemon
|
|
|
|
* *closingd-chan#N*: Each closing negotiation daemon
|
|
|
|
* *onchaind-chan#N*: Each onchain close handling daemon
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2019-11-18 01:27:18 +01:00
|
|
|
|
|
|
|
So, **log-level=debug:plugin** would set debug level logging on all
|
2019-11-18 01:27:18 +01:00
|
|
|
plugins and the plugin manager. **log-level=io:chan#55** would set
|
2019-11-18 01:27:18 +01:00
|
|
|
IO logging on channel number 55 (or 550, for that matter).
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**log-prefix**=*PREFIX*
|
|
|
|
Prefix for log lines: this can be customized if you want to merge logs
|
|
|
|
with multiple daemons.
|
|
|
|
|
|
|
|
**log-file**=*PATH*
|
2022-06-26 06:25:01 +02:00
|
|
|
Log to this file (instead of stdout). If you specify this more than once
|
|
|
|
you'll get more than one log file: **-** is used to mean stdout. Sending
|
|
|
|
lightningd(8) SIGHUP will cause it to reopen each file (useful for log
|
|
|
|
rotation).
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**log-timestamps**=*BOOL*
|
2021-05-03 05:19:43 +02:00
|
|
|
Set this to false to turn off timestamp prefixes (they will still appear
|
|
|
|
in crash log files).
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**rpc-file**=*PATH*
|
|
|
|
Set JSON-RPC socket (or /dev/tty), such as for lightning-cli(1).
|
|
|
|
|
2020-01-24 03:20:45 +01:00
|
|
|
**rpc-file-mode**=*MODE*
|
|
|
|
Set JSON-RPC socket file mode, as a 4-digit octal number.
|
|
|
|
Default is 0600, meaning only the user that launched lightningd
|
|
|
|
can command it.
|
|
|
|
Set to 0660 to allow users with the same group to access the RPC
|
|
|
|
as well.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**daemon**
|
2021-01-25 02:12:23 +01:00
|
|
|
Run in the background, suppress stdout and stderr. Note that you need
|
|
|
|
to specify **log-file** for this case.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**conf**=*PATH*
|
2019-11-23 02:45:53 +01:00
|
|
|
Sets configuration file, and disable reading the normal general and network
|
|
|
|
ones. If this is a relative path, it is relative to the starting directory, not
|
2019-08-10 01:54:18 +02:00
|
|
|
**lightning-dir** (unlike other paths). *PATH* must exist and be
|
|
|
|
readable (we allow missing files in the default case). Using this inside
|
2019-11-23 02:46:40 +01:00
|
|
|
a configuration file is invalid.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2019-09-02 17:48:37 +02:00
|
|
|
**wallet**=*DSN*
|
|
|
|
Identify the location of the wallet. This is a fully qualified data source
|
|
|
|
name, including a scheme such as `sqlite3` or `postgres` followed by the
|
|
|
|
connection parameters.
|
|
|
|
|
2020-04-06 16:01:11 +02:00
|
|
|
The default wallet corresponds to the following DSN:
|
|
|
|
|
|
|
|
```
|
|
|
|
--wallet=sqlite3://$HOME/.lightning/bitcoin/lightningd.sqlite3
|
|
|
|
```
|
|
|
|
|
2021-10-27 11:49:26 +02:00
|
|
|
For the `sqlite3` scheme, you can specify a single backup database file
|
|
|
|
by separating it with a `:` character, like so:
|
|
|
|
|
|
|
|
```
|
|
|
|
--wallet=sqlite3://$HOME/.lightning/bitcoin/lightningd.sqlite3:/backup/lightningd.sqlite3
|
|
|
|
```
|
|
|
|
|
2020-04-06 16:01:11 +02:00
|
|
|
The following is an example of a postgresql wallet DSN:
|
|
|
|
|
|
|
|
```
|
|
|
|
--wallet=postgres://user:pass@localhost:5432/db_name
|
|
|
|
```
|
|
|
|
|
2020-09-23 14:00:27 +02:00
|
|
|
This will connect to a DB server running on `localhost` port `5432`,
|
2020-04-06 16:01:11 +02:00
|
|
|
authenticate with username `user` and password `pass`, and then use the
|
|
|
|
database `db_name`. The database must exist, but the schema will be managed
|
|
|
|
automatically by `lightningd`.
|
|
|
|
|
2019-10-03 16:32:38 +02:00
|
|
|
**encrypted-hsm**
|
|
|
|
If set, you will be prompted to enter a password used to encrypt the `hsm_secret`.
|
|
|
|
Note that once you encrypt the `hsm_secret` this option will be mandatory for
|
|
|
|
`lightningd` to start.
|
2020-06-29 08:28:46 +02:00
|
|
|
If there is no `hsm_secret` yet, `lightningd` will create a new encrypted secret.
|
|
|
|
If you have an unencrypted `hsm_secret` you want to encrypt on-disk, or vice versa,
|
|
|
|
see lightning-hsmtool(8).
|
2019-10-03 16:32:38 +02:00
|
|
|
|
2022-04-10 07:54:16 +02:00
|
|
|
**grpc-port**=*portnum* [plugin `cln-grpc`]
|
|
|
|
|
|
|
|
The port number for the GRPC plugin to listen for incoming
|
|
|
|
connections; default is not to activate the plugin at all.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
### Lightning node customization options
|
|
|
|
|
2019-12-11 10:24:49 +01:00
|
|
|
**alias**=*NAME*
|
2019-12-11 11:32:55 +01:00
|
|
|
Up to 32 bytes of UTF-8 characters to tag your node. Completely silly, since
|
2019-08-10 01:54:18 +02:00
|
|
|
anyone can call their node anything they want. The default is an
|
|
|
|
NSA-style codename derived from your public key, but "Peter Todd" and
|
|
|
|
"VAULTERO" are good options, too.
|
|
|
|
|
2019-12-11 10:24:49 +01:00
|
|
|
**rgb**=*RRGGBB*
|
|
|
|
Your favorite color as a hex code.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**fee-base**=*MILLISATOSHI*
|
|
|
|
Default: 1000. The base fee to charge for every payment which passes
|
|
|
|
through. Note that millisatoshis are a very, very small unit! Changing
|
|
|
|
this value will only affect new channels and not existing ones. If you
|
|
|
|
want to change fees for existing channels, use the RPC call
|
2022-03-21 01:58:28 +01:00
|
|
|
lightning-setchannel(7).
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**fee-per-satoshi**=*MILLIONTHS*
|
|
|
|
Default: 10 (0.001%). This is the proportional fee to charge for every
|
2021-10-24 11:44:56 +02:00
|
|
|
payment which passes through. As percentages are too coarse, it's in
|
2019-08-10 01:54:18 +02:00
|
|
|
millionths, so 10000 is 1%, 1000 is 0.1%. Changing this value will only
|
|
|
|
affect new channels and not existing ones. If you want to change fees
|
2022-03-21 01:58:28 +01:00
|
|
|
for existing channels, use the RPC call lightning-setchannel(7).
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**min-capacity-sat**=*SATOSHI*
|
|
|
|
Default: 10000. This value defines the minimal effective channel
|
2020-08-24 13:26:47 +02:00
|
|
|
capacity in satoshi to accept for channel opening requests. This will
|
|
|
|
reject any opening of a channel which can't pass an HTLC of least this
|
|
|
|
value. Usually this prevents a peer opening a tiny channel, but it
|
|
|
|
can also prevent a channel you open with a reasonable amount and the peer
|
|
|
|
requesting such a large reserve that the capacity of the channel
|
|
|
|
falls below this.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**ignore-fee-limits**=*BOOL*
|
|
|
|
Allow nodes which establish channels to us to set any fee they want.
|
|
|
|
This may result in a channel which cannot be closed, should fees
|
|
|
|
increase, but make channels far more reliable since we never close it
|
|
|
|
due to unreasonable fees.
|
|
|
|
|
2019-12-11 12:37:28 +01:00
|
|
|
**commit-time**=*MILLISECONDS*
|
2019-08-10 01:54:18 +02:00
|
|
|
How long to wait before sending commitment messages to the peer: in
|
|
|
|
theory increasing this would reduce load, but your node would have to be
|
|
|
|
extremely busy node for you to even notice.
|
|
|
|
|
2021-07-08 04:47:03 +02:00
|
|
|
**force-feerates**==*VALUES*
|
|
|
|
Networks like regtest and testnet have unreliable fee estimates: we
|
2021-07-10 13:10:52 +02:00
|
|
|
usually treat them as the minimum (253 sats/kw) if we can't get them.
|
2021-07-08 04:47:03 +02:00
|
|
|
This allows override of one or more of our standard feerates (see
|
|
|
|
lightning-feerates(7)). Up to 5 values, separated by '/' can be
|
|
|
|
provided: if fewer are provided, then the final value is used for the
|
|
|
|
remainder. The values are in per-kw (roughly 1/4 of bitcoind's per-kb
|
2021-07-10 13:10:52 +02:00
|
|
|
values), and the order is "opening", "mutual_close", "unilateral_close",
|
|
|
|
"delayed_to_us", "htlc_resolution", and "penalty".
|
2021-07-08 04:47:03 +02:00
|
|
|
|
|
|
|
You would usually put this option in the per-chain config file, to avoid
|
|
|
|
setting it on Bitcoin mainnet! e.g. `~rusty/.lightning/regtest/config`.
|
|
|
|
|
2022-03-26 14:36:28 +01:00
|
|
|
**htlc-minimum-msat**=*MILLISATOSHI*
|
|
|
|
Default: 0. Sets the minimal allowed HTLC value for newly created channels.
|
|
|
|
If you want to change the `htlc_minimum_msat` for existing channels, use the
|
|
|
|
RPC call lightning-setchannel(7).
|
|
|
|
|
|
|
|
**htlc-maximum-msat**=*MILLISATOSHI*
|
|
|
|
Default: unset (no limit). Sets the maximum allowed HTLC value for newly created
|
|
|
|
channels. If you want to change the `htlc_maximum_msat` for existing channels,
|
|
|
|
use the RPC call lightning-setchannel(7).
|
|
|
|
|
|
|
|
**disable-ip-discovery**
|
|
|
|
Turn off public IP discovery to send `node_announcement` updates that contain
|
|
|
|
the discovered IP with TCP port 9735 as announced address. If unset and you
|
|
|
|
open TCP port 9735 on your router towords your node, your node will remain
|
|
|
|
connectable on changing IP addresses. Note: Will always be disabled if you use
|
|
|
|
'always-use-proxy'.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
### Lightning channel and HTLC options
|
|
|
|
|
2020-04-03 02:03:58 +02:00
|
|
|
**large-channels**
|
|
|
|
Removes capacity limits for channel creation. Version 1.0 of the specification
|
|
|
|
limited channel sizes to 16777215 satoshi. With this option (which your
|
|
|
|
node will advertize to peers), your node will accept larger incoming channels
|
|
|
|
and if the peer supports it, will open larger channels. Note: this option
|
|
|
|
is spelled **large-channels** but it's pronounced **wumbo**.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**watchtime-blocks**=*BLOCKS*
|
|
|
|
How long we need to spot an outdated close attempt: on opening a channel
|
2021-10-24 11:44:56 +02:00
|
|
|
we tell our peer that this is how long they'll have to wait if they
|
2019-08-10 01:54:18 +02:00
|
|
|
perform a unilateral close.
|
|
|
|
|
|
|
|
**max-locktime-blocks**=*BLOCKS*
|
|
|
|
The longest our funds can be delayed (ie. the longest
|
|
|
|
**watchtime-blocks** our peer can ask for, and also the longest HTLC
|
2021-10-24 11:44:56 +02:00
|
|
|
timeout we will accept). If our peer asks for longer, we'll refuse to
|
|
|
|
create a channel, and if an HTLC asks for longer, we'll refuse it.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**funding-confirms**=*BLOCKS*
|
|
|
|
Confirmations required for the funding transaction when the other side
|
|
|
|
opens a channel before the channel is usable.
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**commit-fee**=*PERCENT* [plugin `bcli`]
|
2020-05-17 16:53:37 +02:00
|
|
|
The percentage of *estimatesmartfee 2/CONSERVATIVE* to use for the commitment
|
|
|
|
transactions: default is 100.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**max-concurrent-htlcs**=*INTEGER*
|
|
|
|
Number of HTLCs one channel can handle concurrently in each direction.
|
|
|
|
Should be between 1 and 483 (default 30).
|
|
|
|
|
2021-11-04 19:29:46 +01:00
|
|
|
**max-dust-htlc-exposure-msat**=*MILLISATOSHI*
|
|
|
|
Option which limits the total amount of sats to be allowed as dust on a channel.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
**cltv-delta**=*BLOCKS*
|
|
|
|
The number of blocks between incoming payments and outgoing payments:
|
|
|
|
this needs to be enough to make sure that if we have to, we can close
|
|
|
|
the outgoing payment before the incoming, or redeem the incoming once
|
|
|
|
the outgoing is redeemed.
|
|
|
|
|
|
|
|
**cltv-final**=*BLOCKS*
|
|
|
|
The number of blocks to allow for payments we receive: if we have to, we
|
|
|
|
might need to redeem this on-chain, so this is the number of blocks we
|
|
|
|
have to do that.
|
|
|
|
|
|
|
|
Invoice control options:
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**autocleaninvoice-cycle**=*SECONDS* [plugin `autoclean`]
|
2019-08-10 01:54:18 +02:00
|
|
|
Perform cleanup of expired invoices every *SECONDS* seconds, or disable
|
|
|
|
if 0. Usually unpaid expired invoices are uninteresting, and just take
|
|
|
|
up space in the database.
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**autocleaninvoice-expired-by**=*SECONDS* [plugin `autoclean`]
|
2019-08-10 01:54:18 +02:00
|
|
|
Control how long invoices must have been expired before they are cleaned
|
|
|
|
(if *autocleaninvoice-cycle* is non-zero).
|
|
|
|
|
2020-07-10 14:48:00 +02:00
|
|
|
Payment control options:
|
|
|
|
|
2021-06-16 03:12:17 +02:00
|
|
|
**disable-mpp** [plugin `pay`]
|
2020-07-10 14:48:00 +02:00
|
|
|
Disable the multi-part payment sending support in the `pay` plugin. By default
|
|
|
|
the MPP support is enabled, but it can be desirable to disable in situations
|
|
|
|
in which each payment should result in a single HTLC being forwarded in the
|
|
|
|
network.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
### Networking options
|
|
|
|
|
|
|
|
Note that for simple setups, the implicit *autolisten* option does the
|
2021-11-05 09:53:04 +01:00
|
|
|
right thing: for the mainnet (bitcoin) network it will try to bind to
|
|
|
|
port 9735 on IPv4 and IPv6, and will announce it to peers if it seems
|
2022-06-18 15:18:38 +02:00
|
|
|
like a public address (and other default ports for other networks,
|
|
|
|
as described below).
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2022-04-06 07:09:48 +02:00
|
|
|
Core Lightning also support IPv4/6 address discovery behind NAT routers.
|
2022-03-11 19:14:14 +01:00
|
|
|
If your node detects an new public address, it will update its announcement.
|
|
|
|
For this to work you need to forward the TCP port 9735 to your node.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
You can instead use *addr* to override this (eg. to change the port), or
|
|
|
|
precisely control where to bind and what to announce with the
|
|
|
|
*bind-addr* and *announce-addr* options. These will **disable** the
|
|
|
|
*autolisten* logic, so you must specifiy exactly what you want!
|
|
|
|
|
2019-11-15 09:47:21 +01:00
|
|
|
**addr**=*\[IPADDRESS\[:PORT\]\]|autotor:TORIPADDRESS\[:SERVICEPORT\]\[/torport=TORPORT\]|statictor:TORIPADDRESS\[:SERVICEPORT\]\[/torport=TORPORT\]\[/torblob=\[blob\]\]*
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
Set an IP address (v4 or v6) or automatic Tor address to listen on and
|
|
|
|
(maybe) announce as our node address.
|
|
|
|
|
2020-03-30 11:22:12 +02:00
|
|
|
An empty 'IPADDRESS' is a special value meaning bind to IPv4 and/or
|
|
|
|
IPv6 on all interfaces, '0.0.0.0' means bind to all IPv4
|
2022-06-24 03:28:49 +02:00
|
|
|
interfaces, '::' means 'bind to all IPv6 interfaces' (if you want to
|
|
|
|
specify an IPv6 address *and* a port, use `[]` around the IPv6
|
|
|
|
address, like `[::]:9750`).
|
2021-11-05 09:53:04 +01:00
|
|
|
If 'PORT' is not specified, the default port 9735 is used for mainnet
|
|
|
|
(testnet: 19735, signet: 39735, regtest: 19846).
|
|
|
|
If we can determine a public IP address from the resulting binding,
|
|
|
|
the address is announced.
|
2020-03-30 11:22:12 +02:00
|
|
|
|
|
|
|
If the argument begins with 'autotor:' then it is followed by the
|
|
|
|
IPv4 or IPv6 address of the Tor control port (default port 9051),
|
2021-11-05 09:53:04 +01:00
|
|
|
and this will be used to configure a Tor hidden service for port 9735
|
|
|
|
in case of mainnet (bitcoin) network whereas other networks (testnet,
|
|
|
|
signet, regtest) will set the same default ports they use for non-Tor
|
|
|
|
addresses (see above).
|
2020-03-30 11:22:12 +02:00
|
|
|
The Tor hidden service will be configured to point to the
|
2021-11-05 09:53:04 +01:00
|
|
|
first IPv4 or IPv6 address we bind to and is by default unique to
|
|
|
|
your node's id.
|
2020-03-30 11:22:12 +02:00
|
|
|
|
|
|
|
If the argument begins with 'statictor:' then it is followed by the
|
|
|
|
IPv4 or IPv6 address of the Tor control port (default port 9051),
|
2021-11-05 09:53:04 +01:00
|
|
|
and this will be used to configure a static Tor hidden service.
|
|
|
|
You can add the text '/torblob=BLOB' followed by up to
|
2020-03-30 11:22:12 +02:00
|
|
|
64 Bytes of text to generate from this text a v3 onion service
|
|
|
|
address text unique to the first 32 Byte of this text.
|
|
|
|
You can also use an postfix '/torport=TORPORT' to select the external
|
|
|
|
tor binding. The result is that over tor your node is accessible by a port
|
2021-11-05 09:53:04 +01:00
|
|
|
defined by you and possibly different from your local node port assignment.
|
2020-03-30 11:22:12 +02:00
|
|
|
|
|
|
|
This option can be used multiple times to add more addresses, and
|
|
|
|
its use disables autolisten. If necessary, and 'always-use-proxy'
|
|
|
|
is not specified, a DNS lookup may be done to resolve 'IPADDRESS'
|
|
|
|
or 'TORIPADDRESS'.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**bind-addr**=*\[IPADDRESS\[:PORT\]\]|SOCKETPATH*
|
|
|
|
Set an IP address or UNIX domain socket to listen to, but do not
|
|
|
|
announce. A UNIX domain socket is distinguished from an IP address by
|
|
|
|
beginning with a */*.
|
|
|
|
|
2020-03-30 11:22:12 +02:00
|
|
|
An empty 'IPADDRESS' is a special value meaning bind to IPv4 and/or
|
|
|
|
IPv6 on all interfaces, '0.0.0.0' means bind to all IPv4
|
|
|
|
interfaces, '::' means 'bind to all IPv6 interfaces'. 'PORT' is
|
|
|
|
not specified, 9735 is used.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2020-03-30 11:22:12 +02:00
|
|
|
This option can be used multiple times to add more addresses, and
|
|
|
|
its use disables autolisten. If necessary, and 'always-use-proxy'
|
|
|
|
is not specified, a DNS lookup may be done to resolve 'IPADDRESS'.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**announce-addr**=*IPADDRESS\[:PORT\]|TORADDRESS.onion\[:PORT\]*
|
|
|
|
Set an IP (v4 or v6) address or Tor address to announce; a Tor address
|
|
|
|
is distinguished by ending in *.onion*. *PORT* defaults to 9735.
|
|
|
|
|
2020-03-30 11:22:12 +02:00
|
|
|
Empty or wildcard IPv4 and IPv6 addresses don't make sense here.
|
|
|
|
Also, unlike the 'addr' option, there is no checking that your
|
|
|
|
announced addresses are public (e.g. not localhost).
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2020-03-30 11:22:12 +02:00
|
|
|
This option can be used multiple times to add more addresses, and
|
|
|
|
its use disables autolisten.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2020-03-30 11:22:12 +02:00
|
|
|
If necessary, and 'always-use-proxy' is not specified, a DNS
|
|
|
|
lookup may be done to resolve 'IPADDRESS'.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**offline**
|
|
|
|
Do not bind to any ports, and do not try to reconnect to any peers. This
|
|
|
|
can be useful for maintenance and forensics, so is usually specified on
|
|
|
|
the command line. Overrides all *addr* and *bind-addr* options.
|
|
|
|
|
|
|
|
**autolisten**=*BOOL*
|
|
|
|
By default, we bind (and maybe announce) on IPv4 and IPv6 interfaces if
|
|
|
|
no *addr*, *bind-addr* or *announce-addr* options are specified. Setting
|
|
|
|
this to *false* disables that.
|
|
|
|
|
|
|
|
**proxy**=*IPADDRESS\[:PORT\]*
|
|
|
|
Set a socks proxy to use to connect to Tor nodes (or for all connections
|
2020-09-11 13:00:14 +02:00
|
|
|
if **always-use-proxy** is set). The port defaults to 9050 if not specified.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**always-use-proxy**=*BOOL*
|
|
|
|
Always use the **proxy**, even to connect to normal IP addresses (you
|
|
|
|
can still connect to Unix domain sockets manually). This also disables
|
|
|
|
all DNS lookups, to avoid leaking information.
|
|
|
|
|
|
|
|
**disable-dns**
|
|
|
|
Disable the DNS bootstrapping mechanism to find a node by its node ID.
|
|
|
|
|
|
|
|
**tor-service-password**=*PASSWORD*
|
|
|
|
Set a Tor control password, which may be needed for *autotor:* to
|
|
|
|
authenticate to the Tor control port.
|
|
|
|
|
|
|
|
### Lightning Plugins
|
|
|
|
|
|
|
|
lightningd(8) supports plugins, which offer additional configuration
|
|
|
|
options and JSON-RPC methods, depending on the plugin. Some are supplied
|
|
|
|
by default (usually located in **libexec/c-lightning/plugins/**). If a
|
|
|
|
**plugins** directory exists under *lightning-dir* that is searched for
|
|
|
|
plugins along with any immediate subdirectories). You can specify
|
|
|
|
additional paths too:
|
|
|
|
|
|
|
|
**plugin**=*PATH*
|
2022-04-06 07:09:48 +02:00
|
|
|
Specify a plugin to run as part of Core Lightning. This can be specified
|
2020-11-03 00:20:52 +01:00
|
|
|
multiple times to add multiple plugins. Note that unless plugins themselves
|
|
|
|
specify ordering requirements for being called on various hooks, plugins will
|
|
|
|
be ordered by commandline, then config file.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**plugin-dir**=*DIRECTORY*
|
|
|
|
Specify a directory to look for plugins; all executable files not
|
|
|
|
containing punctuation (other than *.*, *-* or *\_) in 'DIRECTORY* are
|
|
|
|
loaded. *DIRECTORY* must exist; this can be specified multiple times to
|
2020-11-03 00:20:52 +01:00
|
|
|
add multiple directories. The ordering of plugins within a directory
|
|
|
|
is currently unspecified.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**clear-plugins**
|
2020-07-29 13:24:07 +02:00
|
|
|
This option clears all *plugin*, *important-plugin*, and *plugin-dir* options
|
|
|
|
preceeding it,
|
2019-08-10 01:54:18 +02:00
|
|
|
including the default built-in plugin directory. You can still add
|
2020-07-29 13:24:07 +02:00
|
|
|
*plugin-dir*, *plugin*, and *important-plugin* options following this
|
|
|
|
and they will have the normal effect.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
**disable-plugin**=*PLUGIN*
|
2020-05-05 03:15:21 +02:00
|
|
|
If *PLUGIN* contains a /, plugins with the same path as *PLUGIN* will
|
|
|
|
not be loaded at startup. Otherwise, no plugin with that base name will
|
|
|
|
be loaded at startup, whatever directory it is in. This option is useful for
|
|
|
|
disabling a single plugin inside a directory. You can still explicitly
|
|
|
|
load plugins which have been disabled, using lightning-plugin(7) `start`.
|
2019-08-10 01:54:18 +02:00
|
|
|
|
2020-07-29 13:24:07 +02:00
|
|
|
**important-plugin**=*PLUGIN*
|
2022-04-06 07:09:48 +02:00
|
|
|
Speciy a plugin to run as part of Core Lightning.
|
2020-07-29 13:24:07 +02:00
|
|
|
This can be specified multiple times to add multiple plugins.
|
|
|
|
Plugins specified via this option are considered so important, that if the
|
|
|
|
plugin stops for any reason (including via lightning-plugin(7) `stop`),
|
2022-04-06 07:09:48 +02:00
|
|
|
Core Lightning will also stop running.
|
2020-07-29 13:24:07 +02:00
|
|
|
This way, you can monitor crashes of important plugins by simply monitoring
|
2022-04-06 07:09:48 +02:00
|
|
|
if Core Lightning terminates.
|
2020-07-30 08:04:59 +02:00
|
|
|
Built-in plugins, which are installed with lightningd(8), are automatically
|
|
|
|
considered important.
|
2020-07-29 13:24:07 +02:00
|
|
|
|
2021-01-14 04:36:49 +01:00
|
|
|
### Experimental Options
|
|
|
|
|
|
|
|
Experimental options are subject to breakage between releases: they
|
|
|
|
are made available for advanced users who want to test proposed
|
2021-12-25 20:06:31 +01:00
|
|
|
features. When the build is configured _without_ `--enable-experimental-features`,
|
|
|
|
below options are available but disabled by default.
|
|
|
|
A build _with_ `--enable-experimental-features` enables some of below options
|
|
|
|
by default and also adds support for even more features. Supported features can
|
|
|
|
be listed with `lightningd --list-features-only`.
|
2021-01-14 04:36:49 +01:00
|
|
|
|
|
|
|
**experimental-onion-messages**
|
|
|
|
|
|
|
|
Specifying this enables sending, forwarding and receiving onion messages,
|
|
|
|
which are in draft status in the BOLT specifications.
|
|
|
|
|
|
|
|
**experimental-offers**
|
|
|
|
|
|
|
|
Specifying this enables the `offers` and `fetchinvoice` plugins and
|
2021-11-04 15:20:33 +01:00
|
|
|
corresponding functionality, which are in draft status as BOLT12.
|
2021-01-14 04:36:49 +01:00
|
|
|
This usually requires **experimental-onion-messages** as well. See
|
|
|
|
lightning-offer(7) and lightning-fetchinvoice(7).
|
|
|
|
|
2021-07-01 06:28:57 +02:00
|
|
|
**fetchinvoice-noconnect**
|
|
|
|
|
|
|
|
Specifying this prevents `fetchinvoice` and `sendinvoice` from
|
|
|
|
trying to connect directly to the offering node as a last resort.
|
|
|
|
|
2021-03-15 04:39:44 +01:00
|
|
|
**experimental-shutdown-wrong-funding**
|
|
|
|
|
|
|
|
Specifying this allows the `wrong_funding` field in shutdown: if a
|
2021-03-15 21:26:12 +01:00
|
|
|
remote node has opened a channel but claims it used the incorrect txid
|
|
|
|
(and the channel hasn't been used yet at all) this allows them to
|
|
|
|
negotiate a clean shutdown with the txid they offer.
|
2021-03-15 04:39:44 +01:00
|
|
|
|
2021-04-22 14:59:40 +02:00
|
|
|
**experimental-dual-fund**
|
2021-11-04 15:20:33 +01:00
|
|
|
|
2021-04-22 14:59:40 +02:00
|
|
|
Specifying this enables support for the dual funding protocol,
|
|
|
|
allowing both parties to contribute funds to a channel. The decision
|
|
|
|
about whether to add funds or not to a proposed channel is handled
|
|
|
|
automatically by a plugin that implements the appropriate logic for
|
|
|
|
your needs. The default behavior is to not contribute funds.
|
|
|
|
|
2021-11-04 19:29:46 +01:00
|
|
|
**experimental-websocket-port**=*PORT*
|
2021-10-18 02:13:33 +02:00
|
|
|
|
|
|
|
Specifying this enables support for accepting incoming WebSocket
|
|
|
|
connections on that port, on any IPv4 and IPv6 addresses you listen
|
|
|
|
to. The normal protocol is expected to be sent over WebSocket binary
|
|
|
|
frames once the connection is upgraded.
|
|
|
|
|
2019-08-10 01:54:18 +02:00
|
|
|
BUGS
|
|
|
|
----
|
|
|
|
|
|
|
|
You should report bugs on our github issues page, and maybe submit a fix
|
|
|
|
to gain our eternal gratitude!
|
|
|
|
|
|
|
|
AUTHOR
|
|
|
|
------
|
|
|
|
|
2021-06-29 16:34:20 +02:00
|
|
|
Rusty Russell <<rusty@rustcorp.com.au>> wrote this man page, and
|
2019-08-10 01:54:18 +02:00
|
|
|
much of the configuration language, but many others did the hard work of
|
|
|
|
actually implementing these options.
|
|
|
|
|
|
|
|
SEE ALSO
|
|
|
|
--------
|
|
|
|
|
2022-03-21 01:58:28 +01:00
|
|
|
lightning-listconfigs(7) lightning-setchannel(7) lightningd(8)
|
2020-06-29 08:28:46 +02:00
|
|
|
lightning-hsmtool(8)
|
2019-08-10 01:54:18 +02:00
|
|
|
|
|
|
|
RESOURCES
|
|
|
|
---------
|
|
|
|
|
|
|
|
Main web site: <https://github.com/ElementsProject/lightning>
|
|
|
|
|
|
|
|
COPYING
|
|
|
|
-------
|
|
|
|
|
|
|
|
Note: the modules in the ccan/ directory have their own licenses, but
|
|
|
|
the rest of the code is covered by the BSD-style MIT license.
|