mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-07 14:29:33 +01:00
ec83d7a8a5
We also add a test for getlog, since it was never called by the testsuite. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
126 lines
4.5 KiB
Groff
Generated
126 lines
4.5 KiB
Groff
Generated
.TH "LIGHTNING-FUNDPSBT" "7" "" "" "lightning-fundpsbt"
|
||
.SH NAME
|
||
lightning-fundpsbt - Command to populate PSBT inputs from the wallet
|
||
.SH SYNOPSIS
|
||
|
||
\fBfundpsbt\fR \fIsatoshi\fR \fIfeerate\fR \fIstartweight\fR [\fIminconf\fR] [\fIreserve\fR] [\fIlocktime\fR] [\fImin_witness_weight\fR] [\fIexcess_as_change\fR]
|
||
|
||
.SH DESCRIPTION
|
||
|
||
\fBfundpsbt\fR is a low-level RPC command which creates a PSBT using unreserved
|
||
inputs in the wallet, optionally reserving them as well\.
|
||
|
||
|
||
\fIsatoshi\fR is the minimum satoshi value of the output(s) needed (or the
|
||
string "all" meaning use all unreserved inputs)\. If a value, 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\.
|
||
|
||
|
||
\fIfeerate\fR can be one of the feerates listed in \fBlightning-feerates\fR(7),
|
||
or 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\. It can also be a \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\.
|
||
|
||
|
||
\fIstartweight\fR is the weight of the transaction before \fIfundpsbt\fR has
|
||
added any inputs\.
|
||
|
||
|
||
\fIminconf\fR specifies the minimum number of confirmations that used
|
||
outputs should have\. Default is 1\.
|
||
|
||
|
||
\fIreserve\fR is either boolean or a number: if \fItrue\fR or a non-zero
|
||
number then \fIreserveinputs\fR is called (successfully, with
|
||
\fIexclusive\fR true) on the returned PSBT for this number of blocks (or
|
||
72 blocks if \fIreserve\fR is simply \fItrue\fR)\.
|
||
|
||
|
||
\fIlocktime\fR is an optional locktime: if not set, it is set to a recent
|
||
block height\.
|
||
|
||
|
||
\fImin_witness_weight\fR is an optional minimum weight to use for a UTXO's
|
||
witness\. If the actual witness weight is greater than the provided minimum,
|
||
the actual witness weight will be used\.
|
||
|
||
|
||
\fIexcess_as_change\fR is an optional boolean to flag to add a change output
|
||
for the excess sats\.
|
||
|
||
.SH EXAMPLE USAGE
|
||
|
||
Let's assume the caller is trying to produce a 100,000 satoshi output\.
|
||
|
||
|
||
First, the caller estimates the weight of the core (typically 42) and
|
||
known outputs of the transaction (typically (9 + scriptlen) * 4)\. For
|
||
a simple P2WPKH it's a 22 byte scriptpubkey, so that's 124 weight\.
|
||
|
||
|
||
It calls "\fIfundpsbt\fR 100000sat slow 166", which succeeds, and returns
|
||
the \fIpsbt\fR and \fIfeerate_per_kw\fR it used, the \fIestimated_final_weight\fR
|
||
and any \fIexcess_msat\fR\.
|
||
|
||
|
||
If \fIexcess_msat\fR is greater than the cost of adding a change output,
|
||
the caller adds a change output randomly to position 0 or 1 in the
|
||
PSBT\. Say \fIfeerate_per_kw\fR is 253, and the change output is a P2WPKH
|
||
(weight 124), the cost is around 31 sats\. With the dust limit disallowing
|
||
payments below 546 satoshis, we would only create a change output
|
||
if \fIexcess_msat\fR was greater or equal to 31 + 546\.
|
||
|
||
.SH RETURN VALUE
|
||
|
||
On success, returns the \fIpsbt\fR containing the inputs, \fIfeerate_per_kw\fR
|
||
showing the exact numeric feerate it used, \fIestimated_final_weight\fR for
|
||
the estimated weight of the transaction once fully signed, and
|
||
\fIexcess_msat\fR containing the amount above \fIsatoshi\fR which is
|
||
available\. This could be zero, or dust\. If \fIsatoshi\fR was "all",
|
||
then \fIexcess_msat\fR is the entire amount once fees are subtracted
|
||
for the weights of the inputs and startweight\.
|
||
|
||
|
||
If \fIreserve\fR was \fItrue\fR or a non-zero number, then a \fIreservations\fR
|
||
array is returned, exactly like \fIreserveinputs\fR\.
|
||
|
||
|
||
If \fIexcess_as_change\fR is true and the excess is enough to cover
|
||
an additional output above the \fBdust_limit\fR, then an output is
|
||
added to the PSBT for the excess amount\. The \fIexcess_msat\fR will
|
||
be zero\. A \fIchange_outnum\fR will be returned with the index of
|
||
the change output\.
|
||
|
||
|
||
On error the returned object will contain \fBcode\fR and \fBmessage\fR properties,
|
||
with \fBcode\fR being one of the following:
|
||
|
||
.RS
|
||
.IP \[bu]
|
||
-32602: If the given parameters are wrong\.
|
||
.IP \[bu]
|
||
-1: Catchall nonspecific error\.
|
||
.IP \[bu]
|
||
301: Insufficient UTXOs to meet \fIsatoshi\fR value\.
|
||
|
||
.RE
|
||
.SH AUTHOR
|
||
|
||
Rusty Russell \fI<rusty@rustcorp.com.au\fR> is mainly responsible\.
|
||
|
||
.SH SEE ALSO
|
||
|
||
\fBlightning-utxopsbt\fR(7), \fBlightning-reserveinputs\fR(7), \fBlightning-unreserveinputs\fR(7)\.
|
||
|
||
.SH RESOURCES
|
||
|
||
Main web site: \fIhttps://github.com/ElementsProject/lightning\fR
|
||
|
||
\" SHA256STAMP:b02d5c31f0fe6b5423871f4f5859519b41a882388d17f460bd7331f714880126
|