mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-06 05:49:30 +01:00
9ad40f2544
Changelog-Added: JSON-RPC: `fundchannel` now takes optional `request_amt` parameter
212 lines
7.4 KiB
Groff
Generated
212 lines
7.4 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\.
|
||
.IP \[bu]
|
||
\fIrequest_amt\fR is the amount of liquidity you'd like to lease from peer\.
|
||
If peer supports \fBoption_will_fund\fR, indicates to them to include this
|
||
much liquidity into the channel\.
|
||
|
||
.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
|
||
|
||
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\.
|
||
|
||
|
||
On success, an object is returned, containing:
|
||
|
||
.RS
|
||
.IP \[bu]
|
||
\fBtx\fR (hex): The raw transaction which funded the channel
|
||
.IP \[bu]
|
||
\fBtxid\fR (txid): The txid of the transaction which funded the channel
|
||
.IP \[bu]
|
||
\fBchannel_ids\fR (array of objects):
|
||
.RS
|
||
.IP \[bu]
|
||
\fBid\fR (pubkey): The peer we opened the channel with
|
||
.IP \[bu]
|
||
\fBoutnum\fR (u32): The 0-based output index showing which output funded the channel
|
||
.IP \[bu]
|
||
\fBchannel_id\fR (hex): The channel_id of the resulting channel (always 64 characters)
|
||
.IP \[bu]
|
||
\fBclose_to\fR (hex, optional): The raw scriptPubkey which mutual close will go to; only present if \fIclose_to\fR parameter was specified and peer supports \fBoption_upfront_shutdown_script\fR
|
||
|
||
.RE
|
||
|
||
.IP \[bu]
|
||
\fBfailed\fR (array of objects, optional): any peers we failed to open with (if \fIminchannels\fR was specified less than the number of destinations):
|
||
.RS
|
||
.IP \[bu]
|
||
\fBid\fR (pubkey): The peer we failed to open the channel with
|
||
.IP \[bu]
|
||
\fBmethod\fR (string): What stage we failed at (one of "connect", "openchannel_init", "fundchannel_start", "fundchannel_complete")
|
||
.IP \[bu]
|
||
\fBerror\fR (object):
|
||
.RS
|
||
.IP \[bu]
|
||
\fBcode\fR (integer): JSON error code from failing stage
|
||
.IP \[bu]
|
||
\fBmessage\fR (string): Message from stage
|
||
.IP \[bu]
|
||
\fBdata\fR: Additional error data
|
||
|
||
.RE
|
||
|
||
|
||
.RE
|
||
|
||
|
||
.RE
|
||
|
||
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:fa55ac01a568d6b816641ddbfa3c9cccf437dea06df5ec84747f7ef02db6d47e
|