public static final class LightningGrpc.LightningBlockingStub extends io.grpc.stub.AbstractBlockingStub<LightningGrpc.LightningBlockingStub>
Lightning is the main RPC server of the daemon.
Modifier and Type | Method and Description |
---|---|
LightningApi.AbandonChannelResponse |
abandonChannel(LightningApi.AbandonChannelRequest request)
lncli: `abandonchannel`
AbandonChannel removes all channel state from the database except for a
close summary.
|
LightningApi.AddInvoiceResponse |
addInvoice(LightningApi.Invoice request)
lncli: `addinvoice`
AddInvoice attempts to add a new invoice to the invoice database.
|
LightningApi.BakeMacaroonResponse |
bakeMacaroon(LightningApi.BakeMacaroonRequest request)
lncli: `bakemacaroon`
BakeMacaroon allows the creation of a new macaroon with custom read and
write permissions.
|
LightningApi.BatchOpenChannelResponse |
batchOpenChannel(LightningApi.BatchOpenChannelRequest request)
lncli: `batchopenchannel`
BatchOpenChannel attempts to open multiple single-funded channels in a
single transaction in an atomic way.
|
protected LightningGrpc.LightningBlockingStub |
build(io.grpc.Channel channel,
io.grpc.CallOptions callOptions) |
LightningApi.ChannelBalanceResponse |
channelBalance(LightningApi.ChannelBalanceRequest request)
lncli: `channelbalance`
ChannelBalance returns a report on the total funds across all open channels,
categorized in local/remote, pending local/remote and unsettled local/remote
balances.
|
LightningApi.CheckMacPermResponse |
checkMacaroonPermissions(LightningApi.CheckMacPermRequest request)
CheckMacaroonPermissions checks whether a request follows the constraints
imposed on the macaroon and that the macaroon is authorized to follow the
provided permissions.
|
java.util.Iterator<LightningApi.CloseStatusUpdate> |
closeChannel(LightningApi.CloseChannelRequest request)
lncli: `closechannel`
CloseChannel attempts to close an active channel identified by its channel
outpoint (ChannelPoint).
|
LightningApi.ClosedChannelsResponse |
closedChannels(LightningApi.ClosedChannelsRequest request)
lncli: `closedchannels`
ClosedChannels returns a description of all the closed channels that
this node was a participant in.
|
LightningApi.ConnectPeerResponse |
connectPeer(LightningApi.ConnectPeerRequest request)
lncli: `connect`
ConnectPeer attempts to establish a connection to a remote peer.
|
LightningApi.DebugLevelResponse |
debugLevel(LightningApi.DebugLevelRequest request)
lncli: `debuglevel`
DebugLevel allows a caller to programmatically set the logging verbosity of
lnd.
|
LightningApi.PayReq |
decodePayReq(LightningApi.PayReqString request)
lncli: `decodepayreq`
DecodePayReq takes an encoded payment request string and attempts to decode
it, returning a full description of the conditions encoded within the
payment request.
|
LightningApi.DeleteAllPaymentsResponse |
deleteAllPayments(LightningApi.DeleteAllPaymentsRequest request)
DeleteAllPayments deletes all outgoing payments from DB.
|
LightningApi.DeleteMacaroonIDResponse |
deleteMacaroonID(LightningApi.DeleteMacaroonIDRequest request)
lncli: `deletemacaroonid`
DeleteMacaroonID deletes the specified macaroon ID and invalidates all
macaroons derived from that ID.
|
LightningApi.DeletePaymentResponse |
deletePayment(LightningApi.DeletePaymentRequest request)
DeletePayment deletes an outgoing payment from DB.
|
LightningApi.ChannelGraph |
describeGraph(LightningApi.ChannelGraphRequest request)
lncli: `describegraph`
DescribeGraph returns a description of the latest graph state from the
point of view of the node.
|
LightningApi.DisconnectPeerResponse |
disconnectPeer(LightningApi.DisconnectPeerRequest request)
lncli: `disconnect`
DisconnectPeer attempts to disconnect one peer from another identified by a
given pubKey.
|
LightningApi.EstimateFeeResponse |
estimateFee(LightningApi.EstimateFeeRequest request)
lncli: `estimatefee`
EstimateFee asks the chain backend to estimate the fee rate and total fees
for a transaction that pays to multiple specified outputs.
|
LightningApi.ChanBackupSnapshot |
exportAllChannelBackups(LightningApi.ChanBackupExportRequest request)
ExportAllChannelBackups returns static channel backups for all existing
channels known to lnd.
|
LightningApi.ChannelBackup |
exportChannelBackup(LightningApi.ExportChannelBackupRequest request)
lncli: `exportchanbackup`
ExportChannelBackup attempts to return an encrypted static channel backup
for the target channel identified by it channel point.
|
LightningApi.FeeReportResponse |
feeReport(LightningApi.FeeReportRequest request)
lncli: `feereport`
FeeReport allows the caller to obtain a report detailing the current fee
schedule enforced by the node globally for each channel.
|
LightningApi.ForwardingHistoryResponse |
forwardingHistory(LightningApi.ForwardingHistoryRequest request)
lncli: `fwdinghistory`
ForwardingHistory allows the caller to query the htlcswitch for a record of
all HTLCs forwarded within the target time range, and integer offset
within that time range, for a maximum number of events.
|
LightningApi.FundingStateStepResp |
fundingStateStep(LightningApi.FundingTransitionMsg request)
FundingStateStep is an advanced funding related call that allows the caller
to either execute some preparatory steps for a funding workflow, or
manually progress a funding workflow.
|
LightningApi.ChannelEdge |
getChanInfo(LightningApi.ChanInfoRequest request)
lncli: `getchaninfo`
GetChanInfo returns the latest authenticated network announcement for the
given channel identified by its channel ID: an 8-byte integer which
uniquely identifies the location of transaction's funding output within the
blockchain.
|
LightningApi.GetInfoResponse |
getInfo(LightningApi.GetInfoRequest request)
lncli: `getinfo`
GetInfo returns general information concerning the lightning node including
it's identity pubkey, alias, the chains it is connected to, and information
concerning the number of open+pending channels.
|
LightningApi.NetworkInfo |
getNetworkInfo(LightningApi.NetworkInfoRequest request)
lncli: `getnetworkinfo`
GetNetworkInfo returns some basic stats about the known channel graph from
the point of view of the node.
|
LightningApi.NodeInfo |
getNodeInfo(LightningApi.NodeInfoRequest request)
lncli: `getnodeinfo`
GetNodeInfo returns the latest advertised, aggregated, and authenticated
channel information for the specified node identified by its public key.
|
LightningApi.NodeMetricsResponse |
getNodeMetrics(LightningApi.NodeMetricsRequest request)
lncli: `getnodemetrics`
GetNodeMetrics returns node metrics calculated from the graph.
|
LightningApi.GetRecoveryInfoResponse |
getRecoveryInfo(LightningApi.GetRecoveryInfoRequest request)
lncli: `getrecoveryinfo`
GetRecoveryInfo returns information concerning the recovery mode including
whether it's in a recovery mode, whether the recovery is finished, and the
progress made so far.
|
LightningApi.TransactionDetails |
getTransactions(LightningApi.GetTransactionsRequest request)
lncli: `listchaintxns`
GetTransactions returns a list describing all the known transactions
relevant to the wallet.
|
LightningApi.ListAliasesResponse |
listAliases(LightningApi.ListAliasesRequest request)
lncli: `listaliases`
ListAliases returns the set of all aliases that have ever existed with
their confirmed SCID (if it exists) and/or the base SCID (in the case of
zero conf).
|
LightningApi.ListChannelsResponse |
listChannels(LightningApi.ListChannelsRequest request)
lncli: `listchannels`
ListChannels returns a description of all the open channels that this node
is a participant in.
|
LightningApi.ListInvoiceResponse |
listInvoices(LightningApi.ListInvoiceRequest request)
lncli: `listinvoices`
ListInvoices returns a list of all the invoices currently stored within the
database.
|
LightningApi.ListMacaroonIDsResponse |
listMacaroonIDs(LightningApi.ListMacaroonIDsRequest request)
lncli: `listmacaroonids`
ListMacaroonIDs returns all root key IDs that are in use.
|
LightningApi.ListPaymentsResponse |
listPayments(LightningApi.ListPaymentsRequest request)
lncli: `listpayments`
ListPayments returns a list of all outgoing payments.
|
LightningApi.ListPeersResponse |
listPeers(LightningApi.ListPeersRequest request)
lncli: `listpeers`
ListPeers returns a verbose listing of all currently active peers.
|
LightningApi.ListPermissionsResponse |
listPermissions(LightningApi.ListPermissionsRequest request)
lncli: `listpermissions`
ListPermissions lists all RPC method URIs and their required macaroon
permissions to access them.
|
LightningApi.ListUnspentResponse |
listUnspent(LightningApi.ListUnspentRequest request)
lncli: `listunspent`
Deprecated, use walletrpc.ListUnspent instead.
|
LightningApi.LookupHtlcResolutionResponse |
lookupHtlcResolution(LightningApi.LookupHtlcResolutionRequest request)
LookupHtlcResolution retrieves a final htlc resolution from the database.
|
LightningApi.Invoice |
lookupInvoice(LightningApi.PaymentHash request)
lncli: `lookupinvoice`
LookupInvoice attempts to look up an invoice according to its payment hash.
|
LightningApi.NewAddressResponse |
newAddress(LightningApi.NewAddressRequest request)
lncli: `newaddress`
NewAddress creates a new address under control of the local wallet.
|
java.util.Iterator<LightningApi.OpenStatusUpdate> |
openChannel(LightningApi.OpenChannelRequest request)
lncli: `openchannel`
OpenChannel attempts to open a singly funded channel specified in the
request to a remote peer.
|
LightningApi.ChannelPoint |
openChannelSync(LightningApi.OpenChannelRequest request)
OpenChannelSync is a synchronous version of the OpenChannel RPC call.
|
LightningApi.PendingChannelsResponse |
pendingChannels(LightningApi.PendingChannelsRequest request)
lncli: `pendingchannels`
PendingChannels returns a list of all the channels that are currently
considered "pending".
|
LightningApi.QueryRoutesResponse |
queryRoutes(LightningApi.QueryRoutesRequest request)
lncli: `queryroutes`
QueryRoutes attempts to query the daemon's Channel Router for a possible
route to a target destination capable of carrying a specific amount of
satoshis.
|
LightningApi.RestoreBackupResponse |
restoreChannelBackups(LightningApi.RestoreChanBackupRequest request)
lncli: `restorechanbackup`
RestoreChannelBackups accepts a set of singular channel backups, or a
single encrypted multi-chan backup and attempts to recover any funds
remaining within the channel.
|
LightningApi.SendCoinsResponse |
sendCoins(LightningApi.SendCoinsRequest request)
lncli: `sendcoins`
SendCoins executes a request to send coins to a particular address.
|
LightningApi.SendCustomMessageResponse |
sendCustomMessage(LightningApi.SendCustomMessageRequest request)
lncli: `sendcustom`
SendCustomMessage sends a custom peer message.
|
LightningApi.SendManyResponse |
sendMany(LightningApi.SendManyRequest request)
lncli: `sendmany`
SendMany handles a request for a transaction that creates multiple specified
outputs in parallel.
|
LightningApi.SendResponse |
sendPaymentSync(LightningApi.SendRequest request)
SendPaymentSync is the synchronous non-streaming version of SendPayment.
|
LightningApi.SendResponse |
sendToRouteSync(LightningApi.SendToRouteRequest request)
SendToRouteSync is a synchronous version of SendToRoute.
|
LightningApi.SignMessageResponse |
signMessage(LightningApi.SignMessageRequest request)
lncli: `signmessage`
SignMessage signs a message with this node's private key.
|
LightningApi.StopResponse |
stopDaemon(LightningApi.StopRequest request)
lncli: `stop`
StopDaemon will send a shutdown request to the interrupt handler, triggering
a graceful shutdown of the daemon.
|
java.util.Iterator<LightningApi.ChanBackupSnapshot> |
subscribeChannelBackups(LightningApi.ChannelBackupSubscription request)
SubscribeChannelBackups allows a client to sub-subscribe to the most up to
date information concerning the state of all channel backups.
|
java.util.Iterator<LightningApi.ChannelEventUpdate> |
subscribeChannelEvents(LightningApi.ChannelEventSubscription request)
SubscribeChannelEvents creates a uni-directional stream from the server to
the client in which any updates relevant to the state of the channels are
sent over.
|
java.util.Iterator<LightningApi.GraphTopologyUpdate> |
subscribeChannelGraph(LightningApi.GraphTopologySubscription request)
SubscribeChannelGraph launches a streaming RPC that allows the caller to
receive notifications upon any changes to the channel graph topology from
the point of view of the responding node.
|
java.util.Iterator<LightningApi.CustomMessage> |
subscribeCustomMessages(LightningApi.SubscribeCustomMessagesRequest request)
lncli: `subscribecustom`
SubscribeCustomMessages subscribes to a stream of incoming custom peer
messages.
|
java.util.Iterator<LightningApi.Invoice> |
subscribeInvoices(LightningApi.InvoiceSubscription request)
SubscribeInvoices returns a uni-directional stream (server -> client) for
notifying the client of newly added/settled invoices.
|
java.util.Iterator<LightningApi.PeerEvent> |
subscribePeerEvents(LightningApi.PeerEventSubscription request)
SubscribePeerEvents creates a uni-directional stream from the server to
the client in which any events relevant to the state of peers are sent
over.
|
java.util.Iterator<LightningApi.Transaction> |
subscribeTransactions(LightningApi.GetTransactionsRequest request)
SubscribeTransactions creates a uni-directional stream from the server to
the client in which any newly discovered transactions relevant to the
wallet are sent over.
|
LightningApi.PolicyUpdateResponse |
updateChannelPolicy(LightningApi.PolicyUpdateRequest request)
lncli: `updatechanpolicy`
UpdateChannelPolicy allows the caller to update the fee schedule and
channel policies for all channels globally, or a particular channel.
|
LightningApi.VerifyChanBackupResponse |
verifyChanBackup(LightningApi.ChanBackupSnapshot request)
VerifyChanBackup allows a caller to verify the integrity of a channel backup
snapshot.
|
LightningApi.VerifyMessageResponse |
verifyMessage(LightningApi.VerifyMessageRequest request)
lncli: `verifymessage`
VerifyMessage verifies a signature over a message and recovers the signer's
public key.
|
LightningApi.WalletBalanceResponse |
walletBalance(LightningApi.WalletBalanceRequest request)
lncli: `walletbalance`
WalletBalance returns total unspent outputs(confirmed and unconfirmed), all
confirmed unspent outputs and all unconfirmed unspent outputs under control
of the wallet.
|
protected LightningGrpc.LightningBlockingStub build(io.grpc.Channel channel, io.grpc.CallOptions callOptions)
build
in class io.grpc.stub.AbstractStub<LightningGrpc.LightningBlockingStub>
public LightningApi.WalletBalanceResponse walletBalance(LightningApi.WalletBalanceRequest request)
lncli: `walletbalance` WalletBalance returns total unspent outputs(confirmed and unconfirmed), all confirmed unspent outputs and all unconfirmed unspent outputs under control of the wallet.
public LightningApi.ChannelBalanceResponse channelBalance(LightningApi.ChannelBalanceRequest request)
lncli: `channelbalance` ChannelBalance returns a report on the total funds across all open channels, categorized in local/remote, pending local/remote and unsettled local/remote balances.
public LightningApi.TransactionDetails getTransactions(LightningApi.GetTransactionsRequest request)
lncli: `listchaintxns` GetTransactions returns a list describing all the known transactions relevant to the wallet.
public LightningApi.EstimateFeeResponse estimateFee(LightningApi.EstimateFeeRequest request)
lncli: `estimatefee` EstimateFee asks the chain backend to estimate the fee rate and total fees for a transaction that pays to multiple specified outputs. When using REST, the `AddrToAmount` map type can be set by appending `&AddrToAmount[<address>]=<amount_to_send>` to the URL. Unfortunately this map type doesn't appear in the REST API documentation because of a bug in the grpc-gateway library.
public LightningApi.SendCoinsResponse sendCoins(LightningApi.SendCoinsRequest request)
lncli: `sendcoins` SendCoins executes a request to send coins to a particular address. Unlike SendMany, this RPC call only allows creating a single output at a time. If neither target_conf, or sat_per_vbyte are set, then the internal wallet will consult its fee model to determine a fee for the default confirmation target.
public LightningApi.ListUnspentResponse listUnspent(LightningApi.ListUnspentRequest request)
lncli: `listunspent` Deprecated, use walletrpc.ListUnspent instead. ListUnspent returns a list of all utxos spendable by the wallet with a number of confirmations between the specified minimum and maximum.
public java.util.Iterator<LightningApi.Transaction> subscribeTransactions(LightningApi.GetTransactionsRequest request)
SubscribeTransactions creates a uni-directional stream from the server to the client in which any newly discovered transactions relevant to the wallet are sent over.
public LightningApi.SendManyResponse sendMany(LightningApi.SendManyRequest request)
lncli: `sendmany` SendMany handles a request for a transaction that creates multiple specified outputs in parallel. If neither target_conf, or sat_per_vbyte are set, then the internal wallet will consult its fee model to determine a fee for the default confirmation target.
public LightningApi.NewAddressResponse newAddress(LightningApi.NewAddressRequest request)
lncli: `newaddress` NewAddress creates a new address under control of the local wallet.
public LightningApi.SignMessageResponse signMessage(LightningApi.SignMessageRequest request)
lncli: `signmessage` SignMessage signs a message with this node's private key. The returned signature string is `zbase32` encoded and pubkey recoverable, meaning that only the message digest and signature are needed for verification.
public LightningApi.VerifyMessageResponse verifyMessage(LightningApi.VerifyMessageRequest request)
lncli: `verifymessage` VerifyMessage verifies a signature over a message and recovers the signer's public key. The signature is only deemed valid if the recovered public key corresponds to a node key in the public Lightning network. The signature must be zbase32 encoded and signed by an active node in the resident node's channel database. In addition to returning the validity of the signature, VerifyMessage also returns the recovered pubkey from the signature.
public LightningApi.ConnectPeerResponse connectPeer(LightningApi.ConnectPeerRequest request)
lncli: `connect` ConnectPeer attempts to establish a connection to a remote peer. This is at the networking level, and is used for communication between nodes. This is distinct from establishing a channel with a peer.
public LightningApi.DisconnectPeerResponse disconnectPeer(LightningApi.DisconnectPeerRequest request)
lncli: `disconnect` DisconnectPeer attempts to disconnect one peer from another identified by a given pubKey. In the case that we currently have a pending or active channel with the target peer, then this action will be not be allowed.
public LightningApi.ListPeersResponse listPeers(LightningApi.ListPeersRequest request)
lncli: `listpeers` ListPeers returns a verbose listing of all currently active peers.
public java.util.Iterator<LightningApi.PeerEvent> subscribePeerEvents(LightningApi.PeerEventSubscription request)
SubscribePeerEvents creates a uni-directional stream from the server to the client in which any events relevant to the state of peers are sent over. Events include peers going online and offline.
public LightningApi.GetInfoResponse getInfo(LightningApi.GetInfoRequest request)
lncli: `getinfo` GetInfo returns general information concerning the lightning node including it's identity pubkey, alias, the chains it is connected to, and information concerning the number of open+pending channels.
public LightningApi.GetRecoveryInfoResponse getRecoveryInfo(LightningApi.GetRecoveryInfoRequest request)
lncli: `getrecoveryinfo` GetRecoveryInfo returns information concerning the recovery mode including whether it's in a recovery mode, whether the recovery is finished, and the progress made so far.
public LightningApi.PendingChannelsResponse pendingChannels(LightningApi.PendingChannelsRequest request)
lncli: `pendingchannels` PendingChannels returns a list of all the channels that are currently considered "pending". A channel is pending if it has finished the funding workflow and is waiting for confirmations for the funding txn, or is in the process of closure, either initiated cooperatively or non-cooperatively.
public LightningApi.ListChannelsResponse listChannels(LightningApi.ListChannelsRequest request)
lncli: `listchannels` ListChannels returns a description of all the open channels that this node is a participant in.
public java.util.Iterator<LightningApi.ChannelEventUpdate> subscribeChannelEvents(LightningApi.ChannelEventSubscription request)
SubscribeChannelEvents creates a uni-directional stream from the server to the client in which any updates relevant to the state of the channels are sent over. Events include new active channels, inactive channels, and closed channels.
public LightningApi.ClosedChannelsResponse closedChannels(LightningApi.ClosedChannelsRequest request)
lncli: `closedchannels` ClosedChannels returns a description of all the closed channels that this node was a participant in.
public LightningApi.ChannelPoint openChannelSync(LightningApi.OpenChannelRequest request)
OpenChannelSync is a synchronous version of the OpenChannel RPC call. This call is meant to be consumed by clients to the REST proxy. As with all other sync calls, all byte slices are intended to be populated as hex encoded strings.
public java.util.Iterator<LightningApi.OpenStatusUpdate> openChannel(LightningApi.OpenChannelRequest request)
lncli: `openchannel` OpenChannel attempts to open a singly funded channel specified in the request to a remote peer. Users are able to specify a target number of blocks that the funding transaction should be confirmed in, or a manual fee rate to us for the funding transaction. If neither are specified, then a lax block confirmation target is used. Each OpenStatusUpdate will return the pending channel ID of the in-progress channel. Depending on the arguments specified in the OpenChannelRequest, this pending channel ID can then be used to manually progress the channel funding flow.
public LightningApi.BatchOpenChannelResponse batchOpenChannel(LightningApi.BatchOpenChannelRequest request)
lncli: `batchopenchannel` BatchOpenChannel attempts to open multiple single-funded channels in a single transaction in an atomic way. This means either all channel open requests succeed at once or all attempts are aborted if any of them fail. This is the safer variant of using PSBTs to manually fund a batch of channels through the OpenChannel RPC.
public LightningApi.FundingStateStepResp fundingStateStep(LightningApi.FundingTransitionMsg request)
FundingStateStep is an advanced funding related call that allows the caller to either execute some preparatory steps for a funding workflow, or manually progress a funding workflow. The primary way a funding flow is identified is via its pending channel ID. As an example, this method can be used to specify that we're expecting a funding flow for a particular pending channel ID, for which we need to use specific parameters. Alternatively, this can be used to interactively drive PSBT signing for funding for partially complete funding transactions.
public java.util.Iterator<LightningApi.CloseStatusUpdate> closeChannel(LightningApi.CloseChannelRequest request)
lncli: `closechannel` CloseChannel attempts to close an active channel identified by its channel outpoint (ChannelPoint). The actions of this method can additionally be augmented to attempt a force close after a timeout period in the case of an inactive peer. If a non-force close (cooperative closure) is requested, then the user can specify either a target number of blocks until the closure transaction is confirmed, or a manual fee rate. If neither are specified, then a default lax, block confirmation target is used.
public LightningApi.AbandonChannelResponse abandonChannel(LightningApi.AbandonChannelRequest request)
lncli: `abandonchannel` AbandonChannel removes all channel state from the database except for a close summary. This method can be used to get rid of permanently unusable channels due to bugs fixed in newer versions of lnd. This method can also be used to remove externally funded channels where the funding transaction was never broadcast. Only available for non-externally funded channels in dev build.
public LightningApi.SendResponse sendPaymentSync(LightningApi.SendRequest request)
SendPaymentSync is the synchronous non-streaming version of SendPayment. This RPC is intended to be consumed by clients of the REST proxy. Additionally, this RPC expects the destination's public key and the payment hash (if any) to be encoded as hex strings.
public LightningApi.SendResponse sendToRouteSync(LightningApi.SendToRouteRequest request)
SendToRouteSync is a synchronous version of SendToRoute. It Will block until the payment either fails or succeeds.
public LightningApi.AddInvoiceResponse addInvoice(LightningApi.Invoice request)
lncli: `addinvoice` AddInvoice attempts to add a new invoice to the invoice database. Any duplicated invoices are rejected, therefore all invoices *must* have a unique payment preimage.
public LightningApi.ListInvoiceResponse listInvoices(LightningApi.ListInvoiceRequest request)
lncli: `listinvoices` ListInvoices returns a list of all the invoices currently stored within the database. Any active debug invoices are ignored. It has full support for paginated responses, allowing users to query for specific invoices through their add_index. This can be done by using either the first_index_offset or last_index_offset fields included in the response as the index_offset of the next request. By default, the first 100 invoices created will be returned. Backwards pagination is also supported through the Reversed flag.
public LightningApi.Invoice lookupInvoice(LightningApi.PaymentHash request)
lncli: `lookupinvoice` LookupInvoice attempts to look up an invoice according to its payment hash. The passed payment hash *must* be exactly 32 bytes, if not, an error is returned.
public java.util.Iterator<LightningApi.Invoice> subscribeInvoices(LightningApi.InvoiceSubscription request)
SubscribeInvoices returns a uni-directional stream (server -> client) for notifying the client of newly added/settled invoices. The caller can optionally specify the add_index and/or the settle_index. If the add_index is specified, then we'll first start by sending add invoice events for all invoices with an add_index greater than the specified value. If the settle_index is specified, the next, we'll send out all settle events for invoices with a settle_index greater than the specified value. One or both of these fields can be set. If no fields are set, then we'll only send out the latest add/settle events.
public LightningApi.PayReq decodePayReq(LightningApi.PayReqString request)
lncli: `decodepayreq` DecodePayReq takes an encoded payment request string and attempts to decode it, returning a full description of the conditions encoded within the payment request.
public LightningApi.ListPaymentsResponse listPayments(LightningApi.ListPaymentsRequest request)
lncli: `listpayments` ListPayments returns a list of all outgoing payments.
public LightningApi.DeletePaymentResponse deletePayment(LightningApi.DeletePaymentRequest request)
DeletePayment deletes an outgoing payment from DB. Note that it will not attempt to delete an In-Flight payment, since that would be unsafe.
public LightningApi.DeleteAllPaymentsResponse deleteAllPayments(LightningApi.DeleteAllPaymentsRequest request)
DeleteAllPayments deletes all outgoing payments from DB. Note that it will not attempt to delete In-Flight payments, since that would be unsafe.
public LightningApi.ChannelGraph describeGraph(LightningApi.ChannelGraphRequest request)
lncli: `describegraph` DescribeGraph returns a description of the latest graph state from the point of view of the node. The graph information is partitioned into two components: all the nodes/vertexes, and all the edges that connect the vertexes themselves. As this is a directed graph, the edges also contain the node directional specific routing policy which includes: the time lock delta, fee information, etc.
public LightningApi.NodeMetricsResponse getNodeMetrics(LightningApi.NodeMetricsRequest request)
lncli: `getnodemetrics` GetNodeMetrics returns node metrics calculated from the graph. Currently the only supported metric is betweenness centrality of individual nodes.
public LightningApi.ChannelEdge getChanInfo(LightningApi.ChanInfoRequest request)
lncli: `getchaninfo` GetChanInfo returns the latest authenticated network announcement for the given channel identified by its channel ID: an 8-byte integer which uniquely identifies the location of transaction's funding output within the blockchain.
public LightningApi.NodeInfo getNodeInfo(LightningApi.NodeInfoRequest request)
lncli: `getnodeinfo` GetNodeInfo returns the latest advertised, aggregated, and authenticated channel information for the specified node identified by its public key.
public LightningApi.QueryRoutesResponse queryRoutes(LightningApi.QueryRoutesRequest request)
lncli: `queryroutes` QueryRoutes attempts to query the daemon's Channel Router for a possible route to a target destination capable of carrying a specific amount of satoshis. The returned route contains the full details required to craft and send an HTLC, also including the necessary information that should be present within the Sphinx packet encapsulated within the HTLC. When using REST, the `dest_custom_records` map type can be set by appending `&dest_custom_records[<record_number>]=<record_data_base64_url_encoded>` to the URL. Unfortunately this map type doesn't appear in the REST API documentation because of a bug in the grpc-gateway library.
public LightningApi.NetworkInfo getNetworkInfo(LightningApi.NetworkInfoRequest request)
lncli: `getnetworkinfo` GetNetworkInfo returns some basic stats about the known channel graph from the point of view of the node.
public LightningApi.StopResponse stopDaemon(LightningApi.StopRequest request)
lncli: `stop` StopDaemon will send a shutdown request to the interrupt handler, triggering a graceful shutdown of the daemon.
public java.util.Iterator<LightningApi.GraphTopologyUpdate> subscribeChannelGraph(LightningApi.GraphTopologySubscription request)
SubscribeChannelGraph launches a streaming RPC that allows the caller to receive notifications upon any changes to the channel graph topology from the point of view of the responding node. Events notified include: new nodes coming online, nodes updating their authenticated attributes, new channels being advertised, updates in the routing policy for a directional channel edge, and when channels are closed on-chain.
public LightningApi.DebugLevelResponse debugLevel(LightningApi.DebugLevelRequest request)
lncli: `debuglevel` DebugLevel allows a caller to programmatically set the logging verbosity of lnd. The logging can be targeted according to a coarse daemon-wide logging level, or in a granular fashion to specify the logging for a target sub-system.
public LightningApi.FeeReportResponse feeReport(LightningApi.FeeReportRequest request)
lncli: `feereport` FeeReport allows the caller to obtain a report detailing the current fee schedule enforced by the node globally for each channel.
public LightningApi.PolicyUpdateResponse updateChannelPolicy(LightningApi.PolicyUpdateRequest request)
lncli: `updatechanpolicy` UpdateChannelPolicy allows the caller to update the fee schedule and channel policies for all channels globally, or a particular channel.
public LightningApi.ForwardingHistoryResponse forwardingHistory(LightningApi.ForwardingHistoryRequest request)
lncli: `fwdinghistory` ForwardingHistory allows the caller to query the htlcswitch for a record of all HTLCs forwarded within the target time range, and integer offset within that time range, for a maximum number of events. If no maximum number of events is specified, up to 100 events will be returned. If no time-range is specified, then events will be returned in the order that they occured. A list of forwarding events are returned. The size of each forwarding event is 40 bytes, and the max message size able to be returned in gRPC is 4 MiB. As a result each message can only contain 50k entries. Each response has the index offset of the last entry. The index offset can be provided to the request to allow the caller to skip a series of records.
public LightningApi.ChannelBackup exportChannelBackup(LightningApi.ExportChannelBackupRequest request)
lncli: `exportchanbackup` ExportChannelBackup attempts to return an encrypted static channel backup for the target channel identified by it channel point. The backup is encrypted with a key generated from the aezeed seed of the user. The returned backup can either be restored using the RestoreChannelBackup method once lnd is running, or via the InitWallet and UnlockWallet methods from the WalletUnlocker service.
public LightningApi.ChanBackupSnapshot exportAllChannelBackups(LightningApi.ChanBackupExportRequest request)
ExportAllChannelBackups returns static channel backups for all existing channels known to lnd. A set of regular singular static channel backups for each channel are returned. Additionally, a multi-channel backup is returned as well, which contains a single encrypted blob containing the backups of each channel.
public LightningApi.VerifyChanBackupResponse verifyChanBackup(LightningApi.ChanBackupSnapshot request)
VerifyChanBackup allows a caller to verify the integrity of a channel backup snapshot. This method will accept either a packed Single or a packed Multi. Specifying both will result in an error.
public LightningApi.RestoreBackupResponse restoreChannelBackups(LightningApi.RestoreChanBackupRequest request)
lncli: `restorechanbackup` RestoreChannelBackups accepts a set of singular channel backups, or a single encrypted multi-chan backup and attempts to recover any funds remaining within the channel. If we are able to unpack the backup, then the new channel will be shown under listchannels, as well as pending channels.
public java.util.Iterator<LightningApi.ChanBackupSnapshot> subscribeChannelBackups(LightningApi.ChannelBackupSubscription request)
SubscribeChannelBackups allows a client to sub-subscribe to the most up to date information concerning the state of all channel backups. Each time a new channel is added, we return the new set of channels, along with a multi-chan backup containing the backup info for all channels. Each time a channel is closed, we send a new update, which contains new new chan back ups, but the updated set of encrypted multi-chan backups with the closed channel(s) removed.
public LightningApi.BakeMacaroonResponse bakeMacaroon(LightningApi.BakeMacaroonRequest request)
lncli: `bakemacaroon` BakeMacaroon allows the creation of a new macaroon with custom read and write permissions. No first-party caveats are added since this can be done offline.
public LightningApi.ListMacaroonIDsResponse listMacaroonIDs(LightningApi.ListMacaroonIDsRequest request)
lncli: `listmacaroonids` ListMacaroonIDs returns all root key IDs that are in use.
public LightningApi.DeleteMacaroonIDResponse deleteMacaroonID(LightningApi.DeleteMacaroonIDRequest request)
lncli: `deletemacaroonid` DeleteMacaroonID deletes the specified macaroon ID and invalidates all macaroons derived from that ID.
public LightningApi.ListPermissionsResponse listPermissions(LightningApi.ListPermissionsRequest request)
lncli: `listpermissions` ListPermissions lists all RPC method URIs and their required macaroon permissions to access them.
public LightningApi.CheckMacPermResponse checkMacaroonPermissions(LightningApi.CheckMacPermRequest request)
CheckMacaroonPermissions checks whether a request follows the constraints imposed on the macaroon and that the macaroon is authorized to follow the provided permissions.
public LightningApi.SendCustomMessageResponse sendCustomMessage(LightningApi.SendCustomMessageRequest request)
lncli: `sendcustom` SendCustomMessage sends a custom peer message.
public java.util.Iterator<LightningApi.CustomMessage> subscribeCustomMessages(LightningApi.SubscribeCustomMessagesRequest request)
lncli: `subscribecustom` SubscribeCustomMessages subscribes to a stream of incoming custom peer messages. To include messages with type outside of the custom range (>= 32768) lnd needs to be compiled with the `dev` build tag, and the message type to override should be specified in lnd's experimental protocol configuration.
public LightningApi.ListAliasesResponse listAliases(LightningApi.ListAliasesRequest request)
lncli: `listaliases` ListAliases returns the set of all aliases that have ever existed with their confirmed SCID (if it exists) and/or the base SCID (in the case of zero conf).
public LightningApi.LookupHtlcResolutionResponse lookupHtlcResolution(LightningApi.LookupHtlcResolutionRequest request)
LookupHtlcResolution retrieves a final htlc resolution from the database. If the htlc has no final resolution yet, a NotFound grpc status code is returned.