mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-03 20:44:54 +01:00
e66937e012
Technically there *are* two feerates that we need to know: - the feerate to use for the funding transaction, and - the feerate to tell our peer to use for our commitment txs/htlc txs As written, `multifundchannel` uses the same feerate for both. This optional parameter will allow us to differentiate between the two, which will be exceedingly handy for anchor output worlds. ;) FIXME: test this Changelog-Added: JSON API: `multifundchannel` has a new optional argument, 'commitment_feerate', which can be used to differentiate between the funding feerate and the channel's initial commitment feerate
181 lines
6.7 KiB
Groff
Generated
181 lines
6.7 KiB
Groff
Generated
.TH "LIGHTNING-MULTIFUNDCHANNEL" "7" "" "" "lightning-multifundchannel"
|
||
.SH NAME
|
||
lightning-multifundchannel - Command for establishing many lightning channels
|
||
.SH SYNOPSIS
|
||
|
||
\fBmultifundchannel\fR \fIdestinations\fR [\fIfeerate\fR] [\fIminconf\fR] [\fIutxos\fR] [\fIminchannels\fR] [\fIcommitment_feerate\fR]
|
||
|
||
.SH DESCRIPTION
|
||
|
||
The \fBmultifundchannel\fR RPC command opens multiple payment channels
|
||
with nodes by committing a single funding transaction to the blockchain
|
||
that is shared by all channels\.
|
||
|
||
|
||
If not already connected, \fBmultifundchannel\fR will automatically attempt
|
||
to connect; you may provide a \fI@host:port\fR hint appended to the node ID
|
||
so that c-lightning can learn how to connect to the node;
|
||
see \fBlightning-connect\fR(7)\.
|
||
|
||
|
||
Once the transaction is confirmed, normal channel operations may begin\.
|
||
Readiness is indicated by \fBlistpeers\fR reporting a \fIstate\fR of
|
||
\fBCHANNELD_NORMAL\fR for the channel\.
|
||
|
||
|
||
\fIdestinations\fR is an array of objects, with the fields:
|
||
|
||
.RS
|
||
.IP \[bu]
|
||
\fIid\fR is the node ID, with an optional \fI@host:port\fR appended to it
|
||
in a manner understood by \fBconnect\fR; see \fBlightning-connect\fR(7)\.
|
||
Each entry in the \fIdestinations\fR array must have a unique node \fIid\fR\.
|
||
.IP \[bu]
|
||
\fIamount\fR is the amount in satoshis taken from the internal wallet
|
||
to fund the channel\.
|
||
The string \fIall\fR can be used to specify all available funds
|
||
(or 16,777,215 satoshi if more is available and large channels were
|
||
not negotiated with the peer)\.
|
||
Otherwise it is in satoshi precision; it can be
|
||
a whole number,
|
||
a whole number ending in \fIsat\fR,
|
||
a whole number ending in \fI000msat\fR, or
|
||
a number with 1 to 8 decimal places ending in \fIbtc\fR\.
|
||
The value cannot be less than the dust limit, currently 546 satoshi
|
||
as of this writing, nor more than 16,777,215 satoshi
|
||
(unless large channels were negotiated with the peer)\.
|
||
.IP \[bu]
|
||
\fIannounce\fR is an optional flag that indicates whether to announce
|
||
the channel with this, default \fBtrue\fR\.
|
||
If set to \fBfalse\fR, the channel is unpublished\.
|
||
.IP \[bu]
|
||
\fIpush_msat\fR is the amount of millisatoshis to outright give to the
|
||
node\.
|
||
This is a gift to the peer, and you do not get a proof-of-payment
|
||
out of this\.
|
||
.IP \[bu]
|
||
\fIclose_to\fR is a Bitcoin address to which the channel funds should be sent to
|
||
on close\. Only valid if both peers have negotiated
|
||
\fBoption_upfront_shutdown_script\fR\. Returns \fBclose_to\fR set to
|
||
closing script iff is negotiated\.
|
||
|
||
.RE
|
||
|
||
There must be at least one entry in \fIdestinations\fR;
|
||
it cannot be an empty array\.
|
||
|
||
|
||
\fIfeerate\fR is an optional feerate used for the opening transaction and, if
|
||
\fIcommitment_feerate\fR is not set, as the initial feerate for
|
||
commitment and HTLC transactions\. It can be one of
|
||
the strings \fIurgent\fR (aim for next block), \fInormal\fR (next 4 blocks or
|
||
so) or \fIslow\fR (next 100 blocks or so) to use lightningd’s internal
|
||
estimates: \fInormal\fR is the default\.
|
||
|
||
|
||
Otherwise, \fIfeerate\fR is a number, with an optional suffix: \fIperkw\fR means
|
||
the number is interpreted as satoshi-per-kilosipa (weight), and \fIperkb\fR
|
||
means it is interpreted bitcoind-style as satoshi-per-kilobyte\. Omitting
|
||
the suffix is equivalent to \fIperkb\fR\.
|
||
|
||
|
||
\fIminconf\fR specifies the minimum number of confirmations that used
|
||
outputs should have\. Default is 1\.
|
||
|
||
|
||
\fIutxos\fR specifies the utxos to be used to fund the channel, as an array
|
||
of "txid:vout"\.
|
||
|
||
|
||
\fIminchannels\fR, if specified, will re-attempt funding as long as at least
|
||
this many peers remain (must not be zero)\.
|
||
The \fBmultifundchannel\fR command will only fail if too many peers fail
|
||
the funding process\.
|
||
|
||
|
||
\fIcommitment_feerate\fR is the initial feerate for commitment and HTLC
|
||
transactions\. See \fIfeerate\fR for valid values\.
|
||
|
||
.SH RETURN VALUE
|
||
|
||
On success, the \fItx\fR and \fItxid\fR of the signed and broadcsted funding
|
||
transaction is returned\.
|
||
This command opens multiple channels with a single large transaction,
|
||
thus only one transaction is returned\.
|
||
|
||
|
||
If \fIminchannels\fR was specified and is less than the number of destinations,
|
||
then it is possible that one or more of the destinations
|
||
do not have a channel even if \fBmultifundchannel\fR succeeded\.
|
||
|
||
|
||
An array of \fIchannel_ids\fR is returned;
|
||
each entry of the array is an object,
|
||
with an \fIid\fR field being the node ID of the peer,
|
||
an \fIoutnum\fR field being the output number of the transaction
|
||
that anchors this channel,
|
||
and \fIchannel_id\fR field being the channel ID with that peer\.
|
||
|
||
|
||
An array of \fIfailed\fR is returned,
|
||
which contains the destinations that were removed
|
||
due to failures (this can only happen on success if \fIminchannels\fR was specified)\.
|
||
Each entry of the array is an object,
|
||
with an \fIid\fR field being the node ID of the removed peer,
|
||
\fImethod\fR field describing what phase of funding the peer failed,
|
||
and \fIerror\fR field of the exact error returned by the method\.
|
||
|
||
|
||
On failure, none of the channels are created\.
|
||
|
||
|
||
The following error codes may occur:
|
||
|
||
.RS
|
||
.IP \[bu]
|
||
-1: Catchall nonspecific error\.
|
||
.IP \[bu]
|
||
300: The maximum allowed funding amount is exceeded\.
|
||
.IP \[bu]
|
||
301: There are not enough funds in the internal wallet (including fees) to create the transaction\.
|
||
.IP \[bu]
|
||
302: The output amount is too small, and would be considered dust\.
|
||
.IP \[bu]
|
||
303: Broadcasting of the funding transaction failed, the internal call to bitcoin-cli returned with an error\.
|
||
|
||
.RE
|
||
|
||
Failure may also occur if \fBlightningd\fR and the peer cannot agree on
|
||
channel parameters (funding limits, channel reserves, fees, etc\.)\.
|
||
See lightning-fundchannel_\fBstart\fR(7) and lightning-fundchannel_\fBcomplete\fR(7)\.
|
||
|
||
|
||
There may be rare edge cases where a communications failure later in
|
||
the channel funding process will cancel the funding locally, but
|
||
the peer thinks the channel is already waiting for funding lockin\.
|
||
In that case, the next time we connect to the peer, our node will
|
||
tell the peer to forget the channel, but some nodes (in particular,
|
||
c-lightning nodes) will disconnect when our node tells them to
|
||
forget the channel\.
|
||
If you immediately \fBmultifundchannel\fR with that peer, it could
|
||
trigger this connect-forget-disconnect behavior, causing the
|
||
second \fBmultifundchannel\fR to fail as well due to disconnection\.
|
||
Doing a \fBconnect\fR with the peers separately, and waiting for a
|
||
few seconds, should help clear this hurdle;
|
||
running \fBmultifundchannel\fR a third time would also clear this\.
|
||
|
||
.SH AUTHOR
|
||
|
||
ZmnSCPxj \fI<ZmnSCPxj@protonmail.com\fR> is mainly responsible\.
|
||
|
||
.SH SEE ALSO
|
||
|
||
\fBlightning-connect\fR(7), lightning-listfunds(), \fBlightning-listpeers\fR(7),
|
||
\fBlightning-fundchannel\fR(7)
|
||
|
||
.SH RESOURCES
|
||
|
||
Main web site: \fIhttps://github.com/ElementsProject/lightning\fR
|
||
|
||
\" SHA256STAMP:45015c53c73dc4d84850c84cb753d62739288365746b47f0403fb67e5f65d582
|