2020-07-15 07:39:47 +02:00
|
|
|
|
.TH "LIGHTNING-FUNDPSBT" "7" "" "" "lightning-fundpsbt"
|
|
|
|
|
.SH NAME
|
|
|
|
|
lightning-fundpsbt - Command to populate PSBT inputs from the wallet
|
|
|
|
|
.SH SYNOPSIS
|
|
|
|
|
|
2021-02-02 20:43:15 +01:00
|
|
|
|
\fBfundpsbt\fR \fIsatoshi\fR \fIfeerate\fR \fIstartweight\fR [\fIminconf\fR] [\fIreserve\fR] [\fIlocktime\fR] [\fImin_witness_weight\fR] [\fIexcess_as_change\fR]
|
2020-07-15 07:39:47 +02:00
|
|
|
|
|
|
|
|
|
.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\.
|
|
|
|
|
|
|
|
|
|
|
2020-07-17 07:45:57 +02:00
|
|
|
|
\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\.
|
2020-07-15 07:39:47 +02:00
|
|
|
|
|
|
|
|
|
|
2020-07-17 07:45:57 +02:00
|
|
|
|
\fIstartweight\fR is the weight of the transaction before \fIfundpsbt\fR has
|
|
|
|
|
added any inputs\.
|
2020-07-15 07:39:47 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
\fIminconf\fR specifies the minimum number of confirmations that used
|
|
|
|
|
outputs should have\. Default is 1\.
|
|
|
|
|
|
|
|
|
|
|
2021-05-26 03:19:37 +02:00
|
|
|
|
\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)\.
|
2020-07-15 07:39:47 +02:00
|
|
|
|
|
2020-08-18 06:24:39 +02:00
|
|
|
|
|
|
|
|
|
\fIlocktime\fR is an optional locktime: if not set, it is set to a recent
|
|
|
|
|
block height\.
|
|
|
|
|
|
2020-11-18 02:45:23 +01:00
|
|
|
|
|
|
|
|
|
\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\.
|
|
|
|
|
|
2021-02-02 20:43:15 +01:00
|
|
|
|
|
|
|
|
|
\fIexcess_as_change\fR is an optional boolean to flag to add a change output
|
|
|
|
|
for the excess sats\.
|
|
|
|
|
|
2020-07-17 07:45:57 +02:00
|
|
|
|
.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
|
2020-09-14 21:56:17 +02:00
|
|
|
|
a simple P2WPKH it's a 22 byte scriptpubkey, so that's 124 weight\.
|
2020-07-17 07:45:57 +02:00
|
|
|
|
|
|
|
|
|
|
2020-09-14 21:56:17 +02:00
|
|
|
|
It calls "\fIfundpsbt\fR 100000sat slow 166", which succeeds, and returns
|
2020-07-17 07:45:57 +02:00
|
|
|
|
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
|
2020-09-14 21:56:17 +02:00
|
|
|
|
(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\.
|
2020-07-17 07:45:57 +02:00
|
|
|
|
|
2020-07-15 07:39:47 +02:00
|
|
|
|
.SH RETURN VALUE
|
|
|
|
|
|
2020-07-17 07:45:57 +02:00
|
|
|
|
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
|
2020-07-15 07:39:47 +02:00
|
|
|
|
\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
|
2020-07-17 07:45:57 +02:00
|
|
|
|
for the weights of the inputs and startweight\.
|
2020-07-15 07:39:47 +02:00
|
|
|
|
|
|
|
|
|
|
2021-05-26 03:19:37 +02:00
|
|
|
|
If \fIreserve\fR was \fItrue\fR or a non-zero number, then a \fIreservations\fR
|
|
|
|
|
array is returned, exactly like \fIreserveinputs\fR\.
|
2020-07-15 07:39:47 +02:00
|
|
|
|
|
|
|
|
|
|
2021-02-02 20:43:15 +01:00
|
|
|
|
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\.
|
|
|
|
|
|
|
|
|
|
|
2020-07-15 07:39:47 +02:00
|
|
|
|
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
|
|
|
|
|
|
2020-08-18 04:22:53 +02:00
|
|
|
|
\fBlightning-utxopsbt\fR(7), \fBlightning-reserveinputs\fR(7), \fBlightning-unreserveinputs\fR(7)\.
|
2020-07-15 07:39:47 +02:00
|
|
|
|
|
|
|
|
|
.SH RESOURCES
|
|
|
|
|
|
|
|
|
|
Main web site: \fIhttps://github.com/ElementsProject/lightning\fR
|
|
|
|
|
|
2021-05-26 03:19:37 +02:00
|
|
|
|
\" SHA256STAMP:6420ab94377f1a25df686e97e79da3c67c69f99978b6177432426dfd45296052
|