mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-01 03:24:41 +01:00
a8d2336ab9
lightning-config(5) -> lightningd-config(5) < <email> > -> <<email>> in markdown files
634 lines
22 KiB
Groff
634 lines
22 KiB
Groff
.TH "LIGHTNINGD-CONFIG" "5" "" "" "lightningd-config"
|
||
.SH NAME
|
||
lightningd-config - Lightning daemon configuration file
|
||
.SH SYNOPSIS
|
||
|
||
\fB~/\.lightning/config\fR
|
||
|
||
.SH DESCRIPTION
|
||
|
||
When \fBlightningd\fR(8) starts up it usually reads a general configuration
|
||
file (default: \fB$HOME/\.lightning/config\fR) then a network-specific
|
||
configuration file (default: \fB$HOME/\.lightning/testnet/config\fR)\. This can
|
||
be changed: see \fI--conf\fR and \fI--lightning-dir\fR\.
|
||
|
||
|
||
General configuration files are processed first, then network-specific
|
||
ones, then command line options: later options override earlier ones
|
||
except \fIaddr\fR options and \fIlog-level\fR with subsystems, which
|
||
accumulate\.
|
||
|
||
|
||
\fIinclude \fR followed by a filename includes another configuration file at that
|
||
point, relative to the current configuration file\.
|
||
|
||
|
||
All these options are mirrored as commandline arguments to
|
||
\fBlightningd\fR(8), so \fI--foo\fR becomes simply \fIfoo\fR in the configuration
|
||
file, and \fI--foo=bar\fR becomes \fIfoo=bar\fR in the configuration file\.
|
||
|
||
|
||
Blank lines and lines beginning with \fI#\fR are ignored\.
|
||
|
||
.SH DEBUGGING
|
||
|
||
\fI--help\fR will show you the defaults for many options; they vary with
|
||
network settings so you can specify \fI--network\fR before \fI--help\fR to see
|
||
the defaults for that network\.
|
||
|
||
|
||
The \fBlightning-listconfigs\fR(7) command will output a valid configuration
|
||
file using the current settings\.
|
||
|
||
.SH OPTIONS
|
||
.SH General options
|
||
|
||
\fBallow-deprecated-apis\fR=\fIBOOL\fR
|
||
Enable deprecated options, JSONRPC commands, fields, etc\. It defaults to
|
||
\fItrue\fR, but you should set it to \fIfalse\fR when testing to ensure that an
|
||
upgrade won’t break your configuration\.
|
||
|
||
|
||
\fBhelp\fR
|
||
Print help and exit\. Not very useful inside a configuration file, but
|
||
fun to put in other’s config files while their computer is unattended\.
|
||
|
||
|
||
\fBversion\fR
|
||
Print version and exit\. Also useless inside a configuration file, but
|
||
putting this in someone’s config file may convince them to read this man
|
||
page\.
|
||
|
||
|
||
Bitcoin control options:
|
||
|
||
|
||
\fBnetwork\fR=\fINETWORK\fR
|
||
Select the network parameters (\fIbitcoin\fR, \fItestnet\fR, \fIsignet\fR, or \fIregtest\fR)\.
|
||
This is not valid within the per-network configuration file\.
|
||
|
||
|
||
\fBmainnet\fR
|
||
Alias for \fInetwork=bitcoin\fR\.
|
||
|
||
|
||
\fBtestnet\fR
|
||
Alias for \fInetwork=testnet\fR\.
|
||
|
||
|
||
\fBsignet\fR
|
||
Alias for \fInetwork=signet\fR\.
|
||
|
||
|
||
\fBbitcoin-cli\fR=\fIPATH\fR [plugin \fBbcli\fR]
|
||
The name of \fIbitcoin-cli\fR executable to run\.
|
||
|
||
|
||
\fBbitcoin-datadir\fR=\fIDIR\fR [plugin \fBbcli\fR]
|
||
\fI-datadir\fR argument to supply to \fBbitcoin-cli\fR(1)\.
|
||
|
||
|
||
\fBbitcoin-rpcuser\fR=\fIUSER\fR [plugin \fBbcli\fR]
|
||
The RPC username for talking to \fBbitcoind\fR(1)\.
|
||
|
||
|
||
\fBbitcoin-rpcpassword\fR=\fIPASSWORD\fR [plugin \fBbcli\fR]
|
||
The RPC password for talking to \fBbitcoind\fR(1)\.
|
||
|
||
|
||
\fBbitcoin-rpcconnect\fR=\fIHOST\fR [plugin \fBbcli\fR]
|
||
The \fBbitcoind\fR(1) RPC host to connect to\.
|
||
|
||
|
||
\fBbitcoin-rpcport\fR=\fIPORT\fR [plugin \fBbcli\fR]
|
||
The \fBbitcoind\fR(1) RPC port to connect to\.
|
||
|
||
|
||
\fBbitcoin-retry-timeout\fR=\fISECONDS\fR [plugin \fBbcli\fR]
|
||
Number of seconds to keep trying a \fBbitcoin-cli\fR(1) command\. If the
|
||
command keeps failing after this time, exit with a fatal error\.
|
||
|
||
|
||
\fBrescan\fR=\fIBLOCKS\fR
|
||
Number of blocks to rescan from the current head, or absolute
|
||
blockheight if negative\. This is only needed if something goes badly
|
||
wrong\.
|
||
|
||
.SH Lightning daemon options
|
||
|
||
\fBlightning-dir\fR=\fIDIR\fR
|
||
Sets the working directory\. All files (except \fI--conf\fR and
|
||
\fI--lightning-dir\fR on the command line) are relative to this\. This
|
||
is only valid on the command-line, or in a configuration file specified
|
||
by \fI--conf\fR\.
|
||
|
||
|
||
\fBsubdaemon\fR=\fISUBDAEMON\fR:\fIPATH\fR
|
||
Specifies an alternate subdaemon binary\.
|
||
Current subdaemons are \fIchanneld\fR, \fIclosingd\fR,
|
||
\fIconnectd\fR, \fIgossipd\fR, \fIhsmd\fR, \fIonchaind\fR, and \fIopeningd\fR\.
|
||
If the supplied path is relative the subdaemon binary is found in the
|
||
working directory\. This option may be specified multiple times\.
|
||
|
||
|
||
So, \fBsubdaemon=hsmd:remote_signer\fR would use a
|
||
hypothetical remote signing proxy instead of the standard \fIlightning_hsmd\fR
|
||
binary\.
|
||
|
||
|
||
\fBpid-file\fR=\fIPATH\fR
|
||
Specify pid file to write to\.
|
||
|
||
|
||
\fBlog-level\fR=\fILEVEL\fR[:\fISUBSYSTEM\fR]
|
||
What log level to print out: options are io, debug, info, unusual,
|
||
broken\. If \fISUBSYSTEM\fR is supplied, this sets the logging level
|
||
for any subsystem containing that string\. Subsystems include:
|
||
|
||
|
||
.RS
|
||
.IP \[bu]
|
||
\fIlightningd\fR: The main lightning daemon
|
||
.IP \[bu]
|
||
\fIdatabase\fR: The database subsystem
|
||
.IP \[bu]
|
||
\fIwallet\fR: The wallet subsystem
|
||
.IP \[bu]
|
||
\fIgossipd\fR: The gossip daemon
|
||
.IP \[bu]
|
||
\fIplugin-manager\fR: The plugin subsystem
|
||
.IP \[bu]
|
||
\fIplugin-P\fR: Each plugin, P = plugin path without directory
|
||
.IP \[bu]
|
||
\fIhsmd\fR: The secret-holding daemon
|
||
.IP \[bu]
|
||
\fIconnectd\fR: The network connection daemon
|
||
.IP \[bu]
|
||
\fIjsonrpc#FD\fR: Each JSONRPC connection, FD = file descriptor number
|
||
|
||
.RE
|
||
|
||
The following subsystems exist for each channel, where N is an incrementing
|
||
internal integer id assigned for the lifetime of the channel:
|
||
|
||
|
||
.RS
|
||
.IP \[bu]
|
||
\fIopeningd-chan#N\fR: Each opening / idling daemon
|
||
.IP \[bu]
|
||
\fIchanneld-chan#N\fR: Each channel management daemon
|
||
.IP \[bu]
|
||
\fIclosingd-chan#N\fR: Each closing negotiation daemon
|
||
.IP \[bu]
|
||
\fIonchaind-chan#N\fR: Each onchain close handling daemon
|
||
|
||
.RE
|
||
|
||
So, \fBlog-level=debug:plugin\fR would set debug level logging on all
|
||
plugins and the plugin manager\. \fBlog-level=io:chan#55\fR would set
|
||
IO logging on channel number 55 (or 550, for that matter)\.
|
||
|
||
|
||
\fBlog-prefix\fR=\fIPREFIX\fR
|
||
Prefix for log lines: this can be customized if you want to merge logs
|
||
with multiple daemons\.
|
||
|
||
|
||
\fBlog-file\fR=\fIPATH\fR
|
||
Log to this file instead of stdout\. Sending \fBlightningd\fR(8) SIGHUP will
|
||
cause it to reopen this file (useful for log rotation)\.
|
||
|
||
|
||
\fBlog-timestamps\fR=\fIBOOL\fR
|
||
Set this to false to turn off timestamp prefixes (they will still appear
|
||
in crash log files)\.
|
||
|
||
|
||
\fBrpc-file\fR=\fIPATH\fR
|
||
Set JSON-RPC socket (or /dev/tty), such as for \fBlightning-cli\fR(1)\.
|
||
|
||
|
||
\fBrpc-file-mode\fR=\fIMODE\fR
|
||
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\.
|
||
|
||
|
||
\fBdaemon\fR
|
||
Run in the background, suppress stdout and stderr\. Note that you need
|
||
to specify \fBlog-file\fR for this case\.
|
||
|
||
|
||
\fBconf\fR=\fIPATH\fR
|
||
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
|
||
\fBlightning-dir\fR (unlike other paths)\. \fIPATH\fR must exist and be
|
||
readable (we allow missing files in the default case)\. Using this inside
|
||
a configuration file is invalid\.
|
||
|
||
|
||
\fBwallet\fR=\fIDSN\fR
|
||
Identify the location of the wallet\. This is a fully qualified data source
|
||
name, including a scheme such as \fBsqlite3\fR or \fBpostgres\fR followed by the
|
||
connection parameters\.
|
||
|
||
|
||
The default wallet corresponds to the following DSN:
|
||
|
||
.nf
|
||
.RS
|
||
--wallet=sqlite3://$HOME/.lightning/bitcoin/lightningd.sqlite3
|
||
.RE
|
||
|
||
.fi
|
||
|
||
The following is an example of a postgresql wallet DSN:
|
||
|
||
.nf
|
||
.RS
|
||
--wallet=postgres://user:pass@localhost:5432/db_name
|
||
.RE
|
||
|
||
.fi
|
||
|
||
This will connect to a DB server running on \fBlocalhost\fR port \fB5432\fR,
|
||
authenticate with username \fBuser\fR and password \fBpass\fR, and then use the
|
||
database \fBdb_name\fR\. The database must exist, but the schema will be managed
|
||
automatically by \fBlightningd\fR\.
|
||
|
||
|
||
\fBencrypted-hsm\fR
|
||
If set, you will be prompted to enter a password used to encrypt the \fBhsm_secret\fR\.
|
||
Note that once you encrypt the \fBhsm_secret\fR this option will be mandatory for
|
||
\fBlightningd\fR to start\.
|
||
If there is no \fBhsm_secret\fR yet, \fBlightningd\fR will create a new encrypted secret\.
|
||
If you have an unencrypted \fBhsm_secret\fR you want to encrypt on-disk, or vice versa,
|
||
see \fBlightning-hsmtool\fR(8)\.
|
||
|
||
.SH Lightning node customization options
|
||
|
||
\fBalias\fR=\fINAME\fR
|
||
Up to 32 bytes of UTF-8 characters to tag your node\. Completely silly, since
|
||
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\.
|
||
|
||
|
||
\fBrgb\fR=\fIRRGGBB\fR
|
||
Your favorite color as a hex code\.
|
||
|
||
|
||
\fBfee-base\fR=\fIMILLISATOSHI\fR
|
||
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
|
||
\fBlightning-setchannelfee\fR(7)\.
|
||
|
||
|
||
\fBfee-per-satoshi\fR=\fIMILLIONTHS\fR
|
||
Default: 10 (0\.001%)\. This is the proportional fee to charge for every
|
||
payment which passes through\. As percentages are too coarse, it’s in
|
||
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
|
||
for existing channels, use the RPC call \fBlightning-setchannelfee\fR(7)\.
|
||
|
||
|
||
\fBmin-capacity-sat\fR=\fISATOSHI\fR
|
||
Default: 10000\. This value defines the minimal effective channel
|
||
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\.
|
||
|
||
|
||
\fBignore-fee-limits\fR=\fIBOOL\fR
|
||
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\.
|
||
|
||
|
||
\fBcommit-time\fR=\fIMILLISECONDS\fR
|
||
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\.
|
||
|
||
.SH Lightning channel and HTLC options
|
||
|
||
\fBlarge-channels\fR
|
||
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 \fBlarge-channels\fR but it's pronounced \fBwumbo\fR\.
|
||
|
||
|
||
\fBwatchtime-blocks\fR=\fIBLOCKS\fR
|
||
How long we need to spot an outdated close attempt: on opening a channel
|
||
we tell our peer that this is how long they’ll have to wait if they
|
||
perform a unilateral close\.
|
||
|
||
|
||
\fBmax-locktime-blocks\fR=\fIBLOCKS\fR
|
||
The longest our funds can be delayed (ie\. the longest
|
||
\fBwatchtime-blocks\fR our peer can ask for, and also the longest HTLC
|
||
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\.
|
||
|
||
|
||
\fBfunding-confirms\fR=\fIBLOCKS\fR
|
||
Confirmations required for the funding transaction when the other side
|
||
opens a channel before the channel is usable\.
|
||
|
||
|
||
\fBcommit-fee\fR=\fIPERCENT\fR [plugin \fBbcli\fR]
|
||
The percentage of \fIestimatesmartfee 2/CONSERVATIVE\fR to use for the commitment
|
||
transactions: default is 100\.
|
||
|
||
|
||
\fBmax-concurrent-htlcs\fR=\fIINTEGER\fR
|
||
Number of HTLCs one channel can handle concurrently in each direction\.
|
||
Should be between 1 and 483 (default 30)\.
|
||
|
||
|
||
\fBcltv-delta\fR=\fIBLOCKS\fR
|
||
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\.
|
||
|
||
|
||
\fBcltv-final\fR=\fIBLOCKS\fR
|
||
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:
|
||
|
||
|
||
\fBautocleaninvoice-cycle\fR=\fISECONDS\fR [plugin \fBautoclean\fR]
|
||
Perform cleanup of expired invoices every \fISECONDS\fR seconds, or disable
|
||
if 0\. Usually unpaid expired invoices are uninteresting, and just take
|
||
up space in the database\.
|
||
|
||
|
||
\fBautocleaninvoice-expired-by\fR=\fISECONDS\fR [plugin \fBautoclean\fR]
|
||
Control how long invoices must have been expired before they are cleaned
|
||
(if \fIautocleaninvoice-cycle\fR is non-zero)\.
|
||
|
||
|
||
Payment control options:
|
||
|
||
|
||
\fBdisable-mpp\fR [plugin \fBpay\fR]
|
||
Disable the multi-part payment sending support in the \fBpay\fR 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\.
|
||
|
||
.SH Networking options
|
||
|
||
Note that for simple setups, the implicit \fIautolisten\fR option does the
|
||
right thing: it will try to bind to port 9735 on IPv4 and IPv6, and will
|
||
announce it to peers if it seems like a public address\.
|
||
|
||
|
||
You can instead use \fIaddr\fR to override this (eg\. to change the port), or
|
||
precisely control where to bind and what to announce with the
|
||
\fIbind-addr\fR and \fIannounce-addr\fR options\. These will \fBdisable\fR the
|
||
\fIautolisten\fR logic, so you must specifiy exactly what you want!
|
||
|
||
|
||
\fBaddr\fR=\fI[IPADDRESS[:PORT]]|autotor:TORIPADDRESS[:SERVICEPORT][/torport=TORPORT]|statictor:TORIPADDRESS[:SERVICEPORT][/torport=TORPORT][/torblob=[blob]]\fR
|
||
|
||
|
||
Set an IP address (v4 or v6) or automatic Tor address to listen on and
|
||
(maybe) announce as our node address\.
|
||
|
||
|
||
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'\. If 'PORT' is
|
||
not specified, 9735 is used\. If we can determine a public IP
|
||
address from the resulting binding, the address is announced\.
|
||
|
||
|
||
If the argument begins with 'autotor:' then it is followed by the
|
||
IPv4 or IPv6 address of the Tor control port (default port 9051),
|
||
and this will be used to configure a Tor hidden service for port 9735\.
|
||
The Tor hidden service will be configured to point to the
|
||
first IPv4 or IPv6 address we bind to\.
|
||
|
||
|
||
If the argument begins with 'statictor:' then it is followed by the
|
||
IPv4 or IPv6 address of the Tor control port (default port 9051),
|
||
and this will be used to configure a static Tor hidden service for port 9735\.
|
||
The Tor hidden service will be configured to point to the
|
||
first IPv4 or IPv6 address we bind to and is by default unique to
|
||
your nodes id\. You can add the text '/torblob=BLOB' followed by up to
|
||
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
|
||
defined by you and possible different from your local node port assignment
|
||
|
||
|
||
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'\.
|
||
|
||
|
||
\fBbind-addr\fR=\fI[IPADDRESS[:PORT]]|SOCKETPATH\fR
|
||
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 \fI/\fR\.
|
||
|
||
|
||
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\.
|
||
|
||
|
||
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'\.
|
||
|
||
|
||
\fBannounce-addr\fR=\fIIPADDRESS[:PORT]|TORADDRESS\.onion[:PORT]\fR
|
||
Set an IP (v4 or v6) address or Tor address to announce; a Tor address
|
||
is distinguished by ending in \fI\.onion\fR\. \fIPORT\fR defaults to 9735\.
|
||
|
||
|
||
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)\.
|
||
|
||
|
||
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'\.
|
||
|
||
|
||
\fBoffline\fR
|
||
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 \fIaddr\fR and \fIbind-addr\fR options\.
|
||
|
||
|
||
\fBautolisten\fR=\fIBOOL\fR
|
||
By default, we bind (and maybe announce) on IPv4 and IPv6 interfaces if
|
||
no \fIaddr\fR, \fIbind-addr\fR or \fIannounce-addr\fR options are specified\. Setting
|
||
this to \fIfalse\fR disables that\.
|
||
|
||
|
||
\fBproxy\fR=\fIIPADDRESS[:PORT]\fR
|
||
Set a socks proxy to use to connect to Tor nodes (or for all connections
|
||
if \fBalways-use-proxy\fR is set)\. The port defaults to 9050 if not specified\.
|
||
|
||
|
||
\fBalways-use-proxy\fR=\fIBOOL\fR
|
||
Always use the \fBproxy\fR, 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\.
|
||
|
||
|
||
\fBdisable-dns\fR
|
||
Disable the DNS bootstrapping mechanism to find a node by its node ID\.
|
||
|
||
|
||
\fBtor-service-password\fR=\fIPASSWORD\fR
|
||
Set a Tor control password, which may be needed for \fIautotor:\fR to
|
||
authenticate to the Tor control port\.
|
||
|
||
.SH Lightning Plugins
|
||
|
||
\fBlightningd\fR(8) supports plugins, which offer additional configuration
|
||
options and JSON-RPC methods, depending on the plugin\. Some are supplied
|
||
by default (usually located in \fBlibexec/c-lightning/plugins/\fR)\. If a
|
||
\fBplugins\fR directory exists under \fIlightning-dir\fR that is searched for
|
||
plugins along with any immediate subdirectories)\. You can specify
|
||
additional paths too:
|
||
|
||
|
||
\fBplugin\fR=\fIPATH\fR
|
||
Specify a plugin to run as part of c-lightning\. This can be specified
|
||
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\.
|
||
|
||
|
||
\fBplugin-dir\fR=\fIDIRECTORY\fR
|
||
Specify a directory to look for plugins; all executable files not
|
||
containing punctuation (other than \fI\.\fR, \fI-\fR or \fI_) in 'DIRECTORY\fR are
|
||
loaded\. \fIDIRECTORY\fR must exist; this can be specified multiple times to
|
||
add multiple directories\. The ordering of plugins within a directory
|
||
is currently unspecified\.
|
||
|
||
|
||
\fBclear-plugins\fR
|
||
This option clears all \fIplugin\fR, \fIimportant-plugin\fR, and \fIplugin-dir\fR options
|
||
preceeding it,
|
||
including the default built-in plugin directory\. You can still add
|
||
\fIplugin-dir\fR, \fIplugin\fR, and \fIimportant-plugin\fR options following this
|
||
and they will have the normal effect\.
|
||
|
||
|
||
\fBdisable-plugin\fR=\fIPLUGIN\fR
|
||
If \fIPLUGIN\fR contains a /, plugins with the same path as \fIPLUGIN\fR 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 \fBlightning-plugin\fR(7) \fBstart\fR\.
|
||
|
||
|
||
\fBimportant-plugin\fR=\fIPLUGIN\fR
|
||
Speciy a plugin to run as part of C-lightning\.
|
||
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 \fBlightning-plugin\fR(7) \fBstop\fR),
|
||
C-lightning will also stop running\.
|
||
This way, you can monitor crashes of important plugins by simply monitoring
|
||
if C-lightning terminates\.
|
||
Built-in plugins, which are installed with \fBlightningd\fR(8), are automatically
|
||
considered important\.
|
||
|
||
.SH Experimental Options
|
||
|
||
Experimental options are subject to breakage between releases: they
|
||
are made available for advanced users who want to test proposed
|
||
features\. If lightningd is built configured with
|
||
\fB--enable-experimental-features\fR these are on by default\.
|
||
|
||
|
||
\fBexperimental-onion-messages\fR
|
||
|
||
|
||
Specifying this enables sending, forwarding and receiving onion messages,
|
||
which are in draft status in the BOLT specifications\.
|
||
|
||
|
||
\fBexperimental-offers\fR
|
||
|
||
|
||
Specifying this enables the \fBoffers\fR and \fBfetchinvoice\fR plugins and
|
||
corresponding functionality, which are in draft status as BOLT12\.
|
||
This usually requires \fBexperimental-onion-messages\fR as well\. See
|
||
\fBlightning-offer\fR(7) and \fBlightning-fetchinvoice\fR(7)\.
|
||
|
||
|
||
\fBexperimental-shutdown-wrong-funding\fR
|
||
|
||
|
||
Specifying this allows the \fBwrong_funding\fR field in shutdown: if a
|
||
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\.
|
||
|
||
|
||
\fBexperimental-dual-fund\fR
|
||
|
||
|
||
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\.
|
||
|
||
.SH BUGS
|
||
|
||
You should report bugs on our github issues page, and maybe submit a fix
|
||
to gain our eternal gratitude!
|
||
|
||
.SH AUTHOR
|
||
|
||
Rusty Russell \fI<rusty@rustcorp.com.au\fR> wrote this man page, and
|
||
much of the configuration language, but many others did the hard work of
|
||
actually implementing these options\.
|
||
|
||
.SH SEE ALSO
|
||
|
||
\fBlightning-listconfigs\fR(7) \fBlightning-setchannelfee\fR(7) \fBlightningd\fR(8)
|
||
\fBlightning-hsmtool\fR(8)
|
||
|
||
.SH RESOURCES
|
||
|
||
Main web site: \fIhttps://github.com/ElementsProject/lightning\fR
|
||
|
||
.SH 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\.
|
||
|
||
\" SHA256STAMP:55425fe062d1f3365ada296e11e57ede0bdda345b1a70583dd82de2da6e55988
|