github.com/decred/dcrlnd@v0.7.6/lnrpc/invoicesrpc/invoices.swagger.json (about)

     1  {
     2    "swagger": "2.0",
     3    "info": {
     4      "title": "invoicesrpc/invoices.proto",
     5      "version": "version not set"
     6    },
     7    "tags": [
     8      {
     9        "name": "Invoices"
    10      }
    11    ],
    12    "consumes": [
    13      "application/json"
    14    ],
    15    "produces": [
    16      "application/json"
    17    ],
    18    "paths": {
    19      "/v2/invoices/cancel": {
    20        "post": {
    21          "summary": "CancelInvoice cancels a currently open invoice. If the invoice is already\ncanceled, this call will succeed. If the invoice is already settled, it will\nfail.",
    22          "operationId": "Invoices_CancelInvoice",
    23          "responses": {
    24            "200": {
    25              "description": "A successful response.",
    26              "schema": {
    27                "$ref": "#/definitions/invoicesrpcCancelInvoiceResp"
    28              }
    29            },
    30            "default": {
    31              "description": "An unexpected error response.",
    32              "schema": {
    33                "$ref": "#/definitions/rpcStatus"
    34              }
    35            }
    36          },
    37          "parameters": [
    38            {
    39              "name": "body",
    40              "in": "body",
    41              "required": true,
    42              "schema": {
    43                "$ref": "#/definitions/invoicesrpcCancelInvoiceMsg"
    44              }
    45            }
    46          ],
    47          "tags": [
    48            "Invoices"
    49          ]
    50        }
    51      },
    52      "/v2/invoices/hodl": {
    53        "post": {
    54          "summary": "AddHoldInvoice creates a hold invoice. It ties the invoice to the hash\nsupplied in the request.",
    55          "operationId": "Invoices_AddHoldInvoice",
    56          "responses": {
    57            "200": {
    58              "description": "A successful response.",
    59              "schema": {
    60                "$ref": "#/definitions/invoicesrpcAddHoldInvoiceResp"
    61              }
    62            },
    63            "default": {
    64              "description": "An unexpected error response.",
    65              "schema": {
    66                "$ref": "#/definitions/rpcStatus"
    67              }
    68            }
    69          },
    70          "parameters": [
    71            {
    72              "name": "body",
    73              "in": "body",
    74              "required": true,
    75              "schema": {
    76                "$ref": "#/definitions/invoicesrpcAddHoldInvoiceRequest"
    77              }
    78            }
    79          ],
    80          "tags": [
    81            "Invoices"
    82          ]
    83        }
    84      },
    85      "/v2/invoices/lookup": {
    86        "get": {
    87          "summary": "LookupInvoiceV2 attempts to look up at invoice. An invoice can be refrenced\nusing either its payment hash, payment address, or set ID.",
    88          "operationId": "Invoices_LookupInvoiceV2",
    89          "responses": {
    90            "200": {
    91              "description": "A successful response.",
    92              "schema": {
    93                "$ref": "#/definitions/lnrpcInvoice"
    94              }
    95            },
    96            "default": {
    97              "description": "An unexpected error response.",
    98              "schema": {
    99                "$ref": "#/definitions/rpcStatus"
   100              }
   101            }
   102          },
   103          "parameters": [
   104            {
   105              "name": "payment_hash",
   106              "in": "query",
   107              "required": false,
   108              "type": "string",
   109              "format": "byte"
   110            },
   111            {
   112              "name": "payment_addr",
   113              "in": "query",
   114              "required": false,
   115              "type": "string",
   116              "format": "byte"
   117            },
   118            {
   119              "name": "set_id",
   120              "in": "query",
   121              "required": false,
   122              "type": "string",
   123              "format": "byte"
   124            },
   125            {
   126              "name": "lookup_modifier",
   127              "description": " - DEFAULT: The default look up modifier, no look up behavior is changed.\n - HTLC_SET_ONLY: Indicates that when a look up is done based on a set_id, then only that set\nof HTLCs related to that set ID should be returned.\n - HTLC_SET_BLANK: Indicates that when a look up is done using a payment_addr, then no HTLCs\nrelated to the payment_addr should be returned. This is useful when one\nwants to be able to obtain the set of associated setIDs with a given\ninvoice, then look up the sub-invoices \"projected\" by that set ID.",
   128              "in": "query",
   129              "required": false,
   130              "type": "string",
   131              "enum": [
   132                "DEFAULT",
   133                "HTLC_SET_ONLY",
   134                "HTLC_SET_BLANK"
   135              ],
   136              "default": "DEFAULT"
   137            }
   138          ],
   139          "tags": [
   140            "Invoices"
   141          ]
   142        }
   143      },
   144      "/v2/invoices/settle": {
   145        "post": {
   146          "summary": "SettleInvoice settles an accepted invoice. If the invoice is already\nsettled, this call will succeed.",
   147          "operationId": "Invoices_SettleInvoice",
   148          "responses": {
   149            "200": {
   150              "description": "A successful response.",
   151              "schema": {
   152                "$ref": "#/definitions/invoicesrpcSettleInvoiceResp"
   153              }
   154            },
   155            "default": {
   156              "description": "An unexpected error response.",
   157              "schema": {
   158                "$ref": "#/definitions/rpcStatus"
   159              }
   160            }
   161          },
   162          "parameters": [
   163            {
   164              "name": "body",
   165              "in": "body",
   166              "required": true,
   167              "schema": {
   168                "$ref": "#/definitions/invoicesrpcSettleInvoiceMsg"
   169              }
   170            }
   171          ],
   172          "tags": [
   173            "Invoices"
   174          ]
   175        }
   176      },
   177      "/v2/invoices/subscribe/{r_hash}": {
   178        "get": {
   179          "summary": "SubscribeSingleInvoice returns a uni-directional stream (server -\u003e client)\nto notify the client of state transitions of the specified invoice.\nInitially the current invoice state is always sent out.",
   180          "operationId": "Invoices_SubscribeSingleInvoice",
   181          "responses": {
   182            "200": {
   183              "description": "A successful response.(streaming responses)",
   184              "schema": {
   185                "type": "object",
   186                "properties": {
   187                  "result": {
   188                    "$ref": "#/definitions/lnrpcInvoice"
   189                  },
   190                  "error": {
   191                    "$ref": "#/definitions/rpcStatus"
   192                  }
   193                },
   194                "title": "Stream result of lnrpcInvoice"
   195              }
   196            },
   197            "default": {
   198              "description": "An unexpected error response.",
   199              "schema": {
   200                "$ref": "#/definitions/rpcStatus"
   201              }
   202            }
   203          },
   204          "parameters": [
   205            {
   206              "name": "r_hash",
   207              "description": "Hash corresponding to the (hold) invoice to subscribe to.",
   208              "in": "path",
   209              "required": true,
   210              "type": "string",
   211              "format": "byte"
   212            }
   213          ],
   214          "tags": [
   215            "Invoices"
   216          ]
   217        }
   218      }
   219    },
   220    "definitions": {
   221      "InvoiceInvoiceState": {
   222        "type": "string",
   223        "enum": [
   224          "OPEN",
   225          "SETTLED",
   226          "CANCELED",
   227          "ACCEPTED"
   228        ],
   229        "default": "OPEN"
   230      },
   231      "invoicesrpcAddHoldInvoiceRequest": {
   232        "type": "object",
   233        "properties": {
   234          "memo": {
   235            "type": "string",
   236            "description": "An optional memo to attach along with the invoice. Used for record keeping\npurposes for the invoice's creator, and will also be set in the description\nfield of the encoded payment request if the description_hash field is not\nbeing used."
   237          },
   238          "hash": {
   239            "type": "string",
   240            "format": "byte",
   241            "title": "The hash of the preimage"
   242          },
   243          "value": {
   244            "type": "string",
   245            "format": "int64",
   246            "description": "The value of this invoice in atoms.\n\nThe fields value and value_m_atoms are mutually exclusive."
   247          },
   248          "value_m_atoms": {
   249            "type": "string",
   250            "format": "int64",
   251            "description": "The value of this invoice in milliatoms.\n\nThe fields value and value_m_atoms are mutually exclusive."
   252          },
   253          "description_hash": {
   254            "type": "string",
   255            "format": "byte",
   256            "description": "Hash (SHA-256) of a description of the payment. Used if the description of\npayment (memo) is too long to naturally fit within the description field\nof an encoded payment request."
   257          },
   258          "expiry": {
   259            "type": "string",
   260            "format": "int64",
   261            "description": "Payment request expiry time in seconds. Default is 3600 (1 hour)."
   262          },
   263          "fallback_addr": {
   264            "type": "string",
   265            "description": "Fallback on-chain address."
   266          },
   267          "cltv_expiry": {
   268            "type": "string",
   269            "format": "uint64",
   270            "description": "Delta to use for the time-lock of the CLTV extended to the final hop."
   271          },
   272          "route_hints": {
   273            "type": "array",
   274            "items": {
   275              "$ref": "#/definitions/lnrpcRouteHint"
   276            },
   277            "description": "Route hints that can each be individually used to assist in reaching the\ninvoice's destination."
   278          },
   279          "private": {
   280            "type": "boolean",
   281            "description": "Whether this invoice should include routing hints for private channels."
   282          }
   283        }
   284      },
   285      "invoicesrpcAddHoldInvoiceResp": {
   286        "type": "object",
   287        "properties": {
   288          "payment_request": {
   289            "type": "string",
   290            "description": "A bare-bones invoice for a payment within the Lightning Network. With the\ndetails of the invoice, the sender has all the data necessary to send a\npayment to the recipient."
   291          },
   292          "add_index": {
   293            "type": "string",
   294            "format": "uint64",
   295            "description": "The \"add\" index of this invoice. Each newly created invoice will increment\nthis index making it monotonically increasing. Callers to the\nSubscribeInvoices call can use this to instantly get notified of all added\ninvoices with an add_index greater than this one."
   296          },
   297          "payment_addr": {
   298            "type": "string",
   299            "format": "byte",
   300            "description": "The payment address of the generated invoice. This value should be used\nin all payments for this invoice as we require it for end to end\nsecurity."
   301          }
   302        }
   303      },
   304      "invoicesrpcCancelInvoiceMsg": {
   305        "type": "object",
   306        "properties": {
   307          "payment_hash": {
   308            "type": "string",
   309            "format": "byte",
   310            "description": "Hash corresponding to the (hold) invoice to cancel."
   311          }
   312        }
   313      },
   314      "invoicesrpcCancelInvoiceResp": {
   315        "type": "object"
   316      },
   317      "invoicesrpcLookupModifier": {
   318        "type": "string",
   319        "enum": [
   320          "DEFAULT",
   321          "HTLC_SET_ONLY",
   322          "HTLC_SET_BLANK"
   323        ],
   324        "default": "DEFAULT",
   325        "description": " - DEFAULT: The default look up modifier, no look up behavior is changed.\n - HTLC_SET_ONLY: Indicates that when a look up is done based on a set_id, then only that set\nof HTLCs related to that set ID should be returned.\n - HTLC_SET_BLANK: Indicates that when a look up is done using a payment_addr, then no HTLCs\nrelated to the payment_addr should be returned. This is useful when one\nwants to be able to obtain the set of associated setIDs with a given\ninvoice, then look up the sub-invoices \"projected\" by that set ID."
   326      },
   327      "invoicesrpcSettleInvoiceMsg": {
   328        "type": "object",
   329        "properties": {
   330          "preimage": {
   331            "type": "string",
   332            "format": "byte",
   333            "description": "Externally discovered pre-image that should be used to settle the hold\ninvoice."
   334          }
   335        }
   336      },
   337      "invoicesrpcSettleInvoiceResp": {
   338        "type": "object"
   339      },
   340      "lnrpcAMP": {
   341        "type": "object",
   342        "properties": {
   343          "root_share": {
   344            "type": "string",
   345            "format": "byte",
   346            "description": "An n-of-n secret share of the root seed from which child payment hashes\nand preimages are derived."
   347          },
   348          "set_id": {
   349            "type": "string",
   350            "format": "byte",
   351            "description": "An identifier for the HTLC set that this HTLC belongs to."
   352          },
   353          "child_index": {
   354            "type": "integer",
   355            "format": "int64",
   356            "description": "A nonce used to randomize the child preimage and child hash from a given\nroot_share."
   357          },
   358          "hash": {
   359            "type": "string",
   360            "format": "byte",
   361            "description": "The payment hash of the AMP HTLC."
   362          },
   363          "preimage": {
   364            "type": "string",
   365            "format": "byte",
   366            "description": "The preimage used to settle this AMP htlc. This field will only be\npopulated if the invoice is in InvoiceState_ACCEPTED or\nInvoiceState_SETTLED."
   367          }
   368        },
   369        "description": "Details specific to AMP HTLCs."
   370      },
   371      "lnrpcAMPInvoiceState": {
   372        "type": "object",
   373        "properties": {
   374          "state": {
   375            "$ref": "#/definitions/lnrpcInvoiceHTLCState",
   376            "description": "The state the HTLCs associated with this setID are in."
   377          },
   378          "settle_index": {
   379            "type": "string",
   380            "format": "uint64",
   381            "description": "The settle index of this HTLC set, if the invoice state is settled."
   382          },
   383          "settle_time": {
   384            "type": "string",
   385            "format": "int64",
   386            "description": "The time this HTLC set was settled expressed in unix epoch."
   387          },
   388          "amt_paid_m_atoms": {
   389            "type": "string",
   390            "format": "int64",
   391            "description": "The total amount paid for the sub-invoice expressed in milli atoms."
   392          }
   393        }
   394      },
   395      "lnrpcFeature": {
   396        "type": "object",
   397        "properties": {
   398          "name": {
   399            "type": "string"
   400          },
   401          "is_required": {
   402            "type": "boolean"
   403          },
   404          "is_known": {
   405            "type": "boolean"
   406          }
   407        }
   408      },
   409      "lnrpcHopHint": {
   410        "type": "object",
   411        "properties": {
   412          "node_id": {
   413            "type": "string",
   414            "description": "The public key of the node at the start of the channel."
   415          },
   416          "chan_id": {
   417            "type": "string",
   418            "format": "uint64",
   419            "description": "The unique identifier of the channel."
   420          },
   421          "fee_base_m_atoms": {
   422            "type": "integer",
   423            "format": "int64",
   424            "description": "The base fee of the channel denominated in MilliAtoms."
   425          },
   426          "fee_proportional_millionths": {
   427            "type": "integer",
   428            "format": "int64",
   429            "description": "The fee rate of the channel for sending one atom across it denominated in\nmillionths of a atom."
   430          },
   431          "cltv_expiry_delta": {
   432            "type": "integer",
   433            "format": "int64",
   434            "description": "The time-lock delta of the channel."
   435          }
   436        }
   437      },
   438      "lnrpcInvoice": {
   439        "type": "object",
   440        "properties": {
   441          "memo": {
   442            "type": "string",
   443            "description": "An optional memo to attach along with the invoice. Used for record keeping\npurposes for the invoice's creator, and will also be set in the description\nfield of the encoded payment request if the description_hash field is not\nbeing used."
   444          },
   445          "r_preimage": {
   446            "type": "string",
   447            "format": "byte",
   448            "description": "The hex-encoded preimage (32 byte) which will allow settling an incoming\nHTLC payable to this preimage. When using REST, this field must be encoded\nas base64."
   449          },
   450          "r_hash": {
   451            "type": "string",
   452            "format": "byte",
   453            "description": "The hash of the preimage. When using REST, this field must be encoded as\nbase64."
   454          },
   455          "value": {
   456            "type": "string",
   457            "format": "int64",
   458            "description": "The value of this invoice in atoms.\n\nThe fields value and value_msat are mutually exclusive."
   459          },
   460          "value_m_atoms": {
   461            "type": "string",
   462            "format": "int64",
   463            "description": "The value of this invoice in milliatoms.\n\nThe fields value and value_msat are mutually exclusive."
   464          },
   465          "settled": {
   466            "type": "boolean",
   467            "title": "Whether this invoice has been fulfilled"
   468          },
   469          "creation_date": {
   470            "type": "string",
   471            "format": "int64",
   472            "title": "When this invoice was created"
   473          },
   474          "settle_date": {
   475            "type": "string",
   476            "format": "int64",
   477            "title": "When this invoice was settled"
   478          },
   479          "payment_request": {
   480            "type": "string",
   481            "description": "A bare-bones invoice for a payment within the Lightning Network. With the\ndetails of the invoice, the sender has all the data necessary to send a\npayment to the recipient."
   482          },
   483          "description_hash": {
   484            "type": "string",
   485            "format": "byte",
   486            "description": "Hash (SHA-256) of a description of the payment. Used if the description of\npayment (memo) is too long to naturally fit within the description field\nof an encoded payment request. When using REST, this field must be encoded\nas base64."
   487          },
   488          "expiry": {
   489            "type": "string",
   490            "format": "int64",
   491            "description": "Payment request expiry time in seconds. Default is 3600 (1 hour)."
   492          },
   493          "fallback_addr": {
   494            "type": "string",
   495            "description": "Fallback on-chain address."
   496          },
   497          "cltv_expiry": {
   498            "type": "string",
   499            "format": "uint64",
   500            "description": "Delta to use for the time-lock of the CLTV extended to the final hop."
   501          },
   502          "route_hints": {
   503            "type": "array",
   504            "items": {
   505              "$ref": "#/definitions/lnrpcRouteHint"
   506            },
   507            "description": "Route hints that can each be individually used to assist in reaching the\ninvoice's destination."
   508          },
   509          "private": {
   510            "type": "boolean",
   511            "description": "Whether this invoice should include routing hints for private channels."
   512          },
   513          "add_index": {
   514            "type": "string",
   515            "format": "uint64",
   516            "description": "The \"add\" index of this invoice. Each newly created invoice will increment\nthis index making it monotonically increasing. Callers to the\nSubscribeInvoices call can use this to instantly get notified of all added\ninvoices with an add_index greater than this one."
   517          },
   518          "settle_index": {
   519            "type": "string",
   520            "format": "uint64",
   521            "description": "The \"settle\" index of this invoice. Each newly settled invoice will\nincrement this index making it monotonically increasing. Callers to the\nSubscribeInvoices call can use this to instantly get notified of all\nsettled invoices with an settle_index greater than this one."
   522          },
   523          "amt_paid": {
   524            "type": "string",
   525            "format": "int64",
   526            "description": "Deprecated, use amt_paid_atoms or amt_paid_m_atoms."
   527          },
   528          "amt_paid_atoms": {
   529            "type": "string",
   530            "format": "int64",
   531            "description": "The amount that was accepted for this invoice, in atoms. This will ONLY\nbe set if this invoice has been settled. We provide this field as if the\ninvoice was created with a zero value, then we need to record what amount\nwas ultimately accepted. Additionally, it's possible that the sender paid\nMORE that was specified in the original invoice. So we'll record that here\nas well."
   532          },
   533          "amt_paid_m_atoms": {
   534            "type": "string",
   535            "format": "int64",
   536            "description": "The amount that was accepted for this invoice, in MilliAtoms. This will\nONLY be set if this invoice has been settled. We provide this field as if\nthe invoice was created with a zero value, then we need to record what\namount was ultimately accepted. Additionally, it's possible that the sender\npaid MORE that was specified in the original invoice. So we'll record that\nhere as well."
   537          },
   538          "state": {
   539            "$ref": "#/definitions/InvoiceInvoiceState",
   540            "description": "The state the invoice is in."
   541          },
   542          "htlcs": {
   543            "type": "array",
   544            "items": {
   545              "$ref": "#/definitions/lnrpcInvoiceHTLC"
   546            },
   547            "description": "List of HTLCs paying to this invoice [EXPERIMENTAL]."
   548          },
   549          "ignore_max_inbound_amt": {
   550            "type": "boolean",
   551            "description": "Whether to forgo checking for the current max inbound amount before\ncreating the invoice. This is only applicable during invoice creation.\n\nWhen creating an invoice, the node will check if there is enough inbound\nbandwidth in at least one of its directly connected channels (after\naccounting for the required reserves) before allowing the invoice to be\ncreated. Specifying this parameter as true will make the node ignore those\nchecks and create the invoice even if it could not possibly have it settled."
   552          },
   553          "features": {
   554            "type": "object",
   555            "additionalProperties": {
   556              "$ref": "#/definitions/lnrpcFeature"
   557            },
   558            "description": "List of features advertised on the invoice."
   559          },
   560          "is_keysend": {
   561            "type": "boolean",
   562            "description": "Indicates if this invoice was a spontaneous payment that arrived via keysend\n[EXPERIMENTAL]."
   563          },
   564          "payment_addr": {
   565            "type": "string",
   566            "format": "byte",
   567            "description": "The payment address of this invoice. This value will be used in MPP\npayments, and also for newer invoices that always require the MPP payload\nfor added end-to-end security."
   568          },
   569          "is_amp": {
   570            "type": "boolean",
   571            "description": "Signals whether or not this is an AMP invoice."
   572          },
   573          "amp_invoice_state": {
   574            "type": "object",
   575            "additionalProperties": {
   576              "$ref": "#/definitions/lnrpcAMPInvoiceState"
   577            },
   578            "description": "Maps a 32-byte hex-encoded set ID to the sub-invoice AMP state for the\ngiven set ID. This field is always populated for AMP invoices, and can be\nused along side LookupInvoice to obtain the HTLC information related to a\ngiven sub-invoice.",
   579            "title": "[EXPERIMENTAL]:"
   580          }
   581        }
   582      },
   583      "lnrpcInvoiceHTLC": {
   584        "type": "object",
   585        "properties": {
   586          "chan_id": {
   587            "type": "string",
   588            "format": "uint64",
   589            "description": "Short channel id over which the htlc was received."
   590          },
   591          "htlc_index": {
   592            "type": "string",
   593            "format": "uint64",
   594            "description": "Index identifying the htlc on the channel."
   595          },
   596          "amt_m_atoms": {
   597            "type": "string",
   598            "format": "uint64",
   599            "description": "The amount of the htlc in msat."
   600          },
   601          "accept_height": {
   602            "type": "integer",
   603            "format": "int32",
   604            "description": "Block height at which this htlc was accepted."
   605          },
   606          "accept_time": {
   607            "type": "string",
   608            "format": "int64",
   609            "description": "Time at which this htlc was accepted."
   610          },
   611          "resolve_time": {
   612            "type": "string",
   613            "format": "int64",
   614            "description": "Time at which this htlc was settled or canceled."
   615          },
   616          "expiry_height": {
   617            "type": "integer",
   618            "format": "int32",
   619            "description": "Block height at which this htlc expires."
   620          },
   621          "state": {
   622            "$ref": "#/definitions/lnrpcInvoiceHTLCState",
   623            "description": "Current state the htlc is in."
   624          },
   625          "custom_records": {
   626            "type": "object",
   627            "additionalProperties": {
   628              "type": "string",
   629              "format": "byte"
   630            },
   631            "description": "Custom tlv records."
   632          },
   633          "mpp_total_amt_m_atoms": {
   634            "type": "string",
   635            "format": "uint64",
   636            "description": "The total amount of the mpp payment in milli-atoms."
   637          },
   638          "amp": {
   639            "$ref": "#/definitions/lnrpcAMP",
   640            "description": "Details relevant to AMP HTLCs, only populated if this is an AMP HTLC."
   641          }
   642        },
   643        "title": "Details of an HTLC that paid to an invoice"
   644      },
   645      "lnrpcInvoiceHTLCState": {
   646        "type": "string",
   647        "enum": [
   648          "ACCEPTED",
   649          "SETTLED",
   650          "CANCELED"
   651        ],
   652        "default": "ACCEPTED"
   653      },
   654      "lnrpcRouteHint": {
   655        "type": "object",
   656        "properties": {
   657          "hop_hints": {
   658            "type": "array",
   659            "items": {
   660              "$ref": "#/definitions/lnrpcHopHint"
   661            },
   662            "description": "A list of hop hints that when chained together can assist in reaching a\nspecific destination."
   663          }
   664        }
   665      },
   666      "protobufAny": {
   667        "type": "object",
   668        "properties": {
   669          "type_url": {
   670            "type": "string"
   671          },
   672          "value": {
   673            "type": "string",
   674            "format": "byte"
   675          }
   676        }
   677      },
   678      "rpcStatus": {
   679        "type": "object",
   680        "properties": {
   681          "code": {
   682            "type": "integer",
   683            "format": "int32"
   684          },
   685          "message": {
   686            "type": "string"
   687          },
   688          "details": {
   689            "type": "array",
   690            "items": {
   691              "$ref": "#/definitions/protobufAny"
   692            }
   693          }
   694        }
   695      }
   696    }
   697  }