Skip to content

Commit

Permalink
doc: document wait for new subsystems, add request & response schemas.
Browse files Browse the repository at this point in the history
Signed-off-by: Rusty Russell <[email protected]>
  • Loading branch information
rustyrussell committed Oct 27, 2023
1 parent a909e48 commit 0de4d18
Show file tree
Hide file tree
Showing 3 changed files with 261 additions and 3 deletions.
43 changes: 40 additions & 3 deletions doc/lightning-wait.7.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,9 @@ the current index, though naturally this is racy!).

*subsystem* is one of:

- `invoices`: corresponding to `listinvoices`.
- `invoices`: corresponding to `listinvoices` (added in *v23.08*)
- `sendpays`: corresponding to `listsendpays` (added in *v23.11*)
- `forwards`: corresponding to `listforwards` (added in *v23.11*)


RELIABILITY
Expand Down Expand Up @@ -57,7 +59,41 @@ This is obviously inefficient, so there are two optimizations:

RETURN VALUE
------------
FIXME
[comment]: # (GENERATE-FROM-SCHEMA-START)
On success, an object is returned, containing:

- **subsystem** (string) (one of "invoices", "forwards", "sendpays")
- **created** (u64, optional): 1-based index indicating order entry was created
- **updated** (u64, optional): 1-based index indicating order entry was updated
- **deleted** (u64, optional): 1-based index indicating order entry was deleted

If **subsystem** is "invoices":

- **details** (object, optional):
- **status** (string, optional): Whether it's paid, unpaid or unpayable (one of "unpaid", "paid", "expired")
- **label** (string, optional): unique label supplied at invoice creation
- **description** (string, optional): description used in the invoice
- **bolt11** (string, optional): the BOLT11 string
- **bolt12** (string, optional): the BOLT12 string

If **subsystem** is "forwards":

- **details** (object, optional):
- **status** (string, optional): still ongoing, completed, failed locally, or failed after forwarding (one of "offered", "settled", "failed", "local\_failed")
- **in\_channel** (short\_channel\_id, optional): unique label supplied at invoice creation
- **in\_htlc\_id** (u64, optional): the unique HTLC id the sender gave this (not present if incoming channel was closed before ugprade to v22.11)
- **in\_msat** (msat, optional): the value of the incoming HTLC
- **out\_channel** (short\_channel\_id, optional): the channel that the HTLC (trying to) forward to

If **subsystem** is "sendpays":

- **details** (object, optional):
- **status** (string, optional): status of the payment (one of "pending", "failed", "complete")
- **partid** (u64, optional): Part number (for multiple parts to a single payment)
- **groupid** (u64, optional): Grouping key to disambiguate multiple attempts to pay an invoice or the same payment\_hash
- **payment\_hash** (hash, optional): the hash of the *payment\_preimage* which will prove payment

[comment]: # (GENERATE-FROM-SCHEMA-END)

On error the returned object will contain `code` and `message` properties,
with `code` being one of the following:
Expand All @@ -73,9 +109,10 @@ responsible.
SEE ALSO
--------

lightning-listinvoice(7)
lightning-listinvoice(7), lightning-listforwards(7), lightning-listsendpays(7)

RESOURCES
---------

Main web site: <https://github.com/ElementsProject/lightning>
[comment]: # ( SHA256STAMP:a3c55b5c6ee055fedc65954c784e72f0a7fbd14cef74b0e69bb254d64b3f0e77)
32 changes: 32 additions & 0 deletions doc/schemas/wait.request.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
{
"$schema": "http://json-schema.org/draft-07/schema#",
"type": "object",
"added": "v23.08",
"additionalProperties": false,
"required": [
"subsystem",
"indexname",
"nextvalue"
],
"properties": {
"subsystem": {
"type": "string",
"enum": [
"invoices",
"forwards",
"sendpays"
]
},
"indexname": {
"type": "string",
"enum": [
"created",
"updated",
"deleted"
]
},
"nextvalue": {
"type": "u64"
}
}
}
189 changes: 189 additions & 0 deletions doc/schemas/wait.schema.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,189 @@
{
"$schema": "http://json-schema.org/draft-07/schema#",
"type": "object",
"additionalProperties": false,
"required": [
"subsystem"
],
"properties": {
"subsystem": {
"type": "string",
"enum": [
"invoices",
"forwards",
"sendpays"
]
},
"created": {
"type": "u64",
"description": "1-based index indicating order entry was created"
},
"updated": {
"type": "u64",
"description": "1-based index indicating order entry was updated"
},
"deleted": {
"type": "u64",
"description": "1-based index indicating order entry was deleted"
},
"details": {}
},
"allOf": [
{
"if": {
"additionalProperties": true,
"properties": {
"subsystem": {
"type": "string",
"enum": [
"invoices"
]
}
}
},
"then": {
"additionalProperties": false,
"properties": {
"subsystem": {},
"created": {},
"updated": {},
"deleted": {},
"details": {
"type": "object",
"additionalProperties": false,
"properties": {
"status": {
"type": "string",
"enum": [
"unpaid",
"paid",
"expired"
],
"description": "Whether it's paid, unpaid or unpayable"
},
"label": {
"type": "string",
"description": "unique label supplied at invoice creation"
},
"description": {
"type": "string",
"description": "description used in the invoice"
},
"bolt11": {
"type": "string",
"description": "the BOLT11 string"
},
"bolt12": {
"type": "string",
"description": "the BOLT12 string"
}
}
}
}
}
},
{
"if": {
"additionalProperties": true,
"properties": {
"subsystem": {
"type": "string",
"enum": [
"forwards"
]
}
}
},
"then": {
"additionalProperties": false,
"properties": {
"subsystem": {},
"created": {},
"updated": {},
"deleted": {},
"details": {
"type": "object",
"additionalProperties": false,
"properties": {
"status": {
"type": "string",
"enum": [
"offered",
"settled",
"failed",
"local_failed"
],
"description": "still ongoing, completed, failed locally, or failed after forwarding"
},
"in_channel": {
"type": "short_channel_id",
"description": "unique label supplied at invoice creation"
},
"in_htlc_id": {
"type": "u64",
"description": "the unique HTLC id the sender gave this (not present if incoming channel was closed before ugprade to v22.11)"
},
"in_msat": {
"type": "msat",
"description": "the value of the incoming HTLC"
},
"out_channel": {
"type": "short_channel_id",
"description": "the channel that the HTLC (trying to) forward to"
}
}
}
}
}
},
{
"if": {
"additionalProperties": true,
"properties": {
"subsystem": {
"type": "string",
"enum": [
"sendpays"
]
}
}
},
"then": {
"additionalProperties": false,
"properties": {
"subsystem": {},
"created": {},
"updated": {},
"deleted": {},
"details": {
"type": "object",
"additionalProperties": false,
"properties": {
"status": {
"type": "string",
"enum": [
"pending",
"failed",
"complete"
],
"description": "status of the payment"
},
"partid": {
"type": "u64",
"description": "Part number (for multiple parts to a single payment)"
},
"groupid": {
"type": "u64",
"description": "Grouping key to disambiguate multiple attempts to pay an invoice or the same payment_hash"
},
"payment_hash": {
"type": "hash",
"description": "the hash of the *payment_preimage* which will prove payment"
}
}
}
}
}
}
]
}

0 comments on commit 0de4d18

Please sign in to comment.