mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-07 14:29:33 +01:00
2ddecdc95a
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Changelog-Fixed: doc: Epic documentation rewrite: each now lists complete and accurate JSON output, tested against testsuite.
103 lines
4.0 KiB
Markdown
103 lines
4.0 KiB
Markdown
lightning-waitsendpay -- Command for sending a payment via a route
|
|
==================================================================
|
|
|
|
SYNOPSIS
|
|
--------
|
|
|
|
**waitsendpay** *payment\_hash* \[*timeout*\] \[*partid*\]
|
|
|
|
DESCRIPTION
|
|
-----------
|
|
|
|
The **waitsendpay** RPC command polls or waits for the status of an
|
|
outgoing payment that was initiated by a previous **sendpay**
|
|
invocation.
|
|
|
|
The *partid* argument must match that of the **sendpay** command.
|
|
|
|
Optionally the client may provide a *timeout*, an integer in seconds,
|
|
for this RPC command to return. If the *timeout* is provided and the
|
|
given amount of time passes without the payment definitely succeeding or
|
|
definitely failing, this command returns with a 200 error code (payment
|
|
still in progress). If *timeout* is not provided this call will wait
|
|
indefinitely.
|
|
|
|
Indicating a *timeout* of 0 effectively makes this call a pollable query
|
|
of the status of the payment.
|
|
|
|
If the payment completed with success, this command returns with
|
|
success. Otherwise, if the payment completed with failure, this command
|
|
returns an error.
|
|
|
|
RETURN VALUE
|
|
------------
|
|
|
|
[comment]: # (GENERATE-FROM-SCHEMA-START)
|
|
On success, an object is returned, containing:
|
|
- **id** (u64): unique ID for this payment attempt
|
|
- **payment_hash** (hex): the hash of the *payment_preimage* which will prove payment (always 64 characters)
|
|
- **status** (string): status of the payment (always "complete")
|
|
- **created_at** (u64): the UNIX timestamp showing when this payment was initiated
|
|
- **amount_sent_msat** (msat): The amount sent
|
|
- **amount_msat** (msat, optional): The amount delivered to destination (if known)
|
|
- **destination** (pubkey, optional): the final destination of the payment if known
|
|
- **label** (string, optional): the label, if given to sendpay
|
|
- **partid** (u64, optional): the *partid*, if given to sendpay
|
|
- **bolt11** (string, optional): the bolt11 string (if pay supplied one)
|
|
- **bolt12** (string, optional): the bolt12 string (if supplied for pay: **experimental-offers** only).
|
|
|
|
If **status** is "complete":
|
|
- **payment_preimage** (hex): the proof of payment: SHA256 of this **payment_hash** (always 64 characters)
|
|
[comment]: # (GENERATE-FROM-SCHEMA-END)
|
|
|
|
On error, and even if the error occurred from a node other than the
|
|
final destination, the route table will no longer be updated. Use the
|
|
*exclude* parameter of the `getroute` command to ignore the failing
|
|
route.
|
|
|
|
The following error codes may occur:
|
|
- -1: Catchall nonspecific error.
|
|
- 200: Timed out before the payment could complete.
|
|
- 202: Unparseable onion reply. The *data* field of the error will
|
|
have an *onionreply* field, a hex string representation of the raw
|
|
onion reply.
|
|
- 203: Permanent failure at destination. The *data* field of the error
|
|
will be routing failure object.
|
|
- 204: Failure along route; retry a different route. The *data* field
|
|
of the error will be routing failure object.
|
|
- 208: A payment for *payment\_hash* was never made and there is
|
|
nothing to wait for.
|
|
- 209: The payment already failed, but the reason for failure was not
|
|
stored. This should only occur when querying failed payments on very
|
|
old databases.
|
|
|
|
A routing failure object has the fields below:
|
|
- *erring\_index*: The index of the node along the route that reported
|
|
the error. 0 for the local node, 1 for the first hop, and so on.
|
|
- *erring\_node*: The hex string of the pubkey id of the node that
|
|
reported the error.
|
|
- *erring\_channel*: The short channel ID of the channel that has the
|
|
error (or the final channel if the destination raised the error).
|
|
- *erring\_direction*: The direction of traversing the
|
|
*erring\_channel*:
|
|
- *failcode*: The failure code, as per BOLT \#4.
|
|
- *failcodename*: The human-readable name corresponding to *failcode*,
|
|
if known.
|
|
|
|
AUTHOR
|
|
------
|
|
|
|
ZmnSCPxj <<ZmnSCPxj@protonmail.com>> is mainly responsible.
|
|
|
|
SEE ALSO
|
|
--------
|
|
|
|
lightning-sendpay(7), lightning-pay(7).
|
|
|
|
RESOURCES
|
|
---------
|
|
|
|
Main web site: <https://github.com/ElementsProject/lightning>
|
|
|
|
[comment]: # ( SHA256STAMP:3efc46e3dc2254ddfb4a82d4b3bb1936ff0a400a3cf19ce4c40a717412f83ee7)
|