lnd/lnrpc
Elle Mouton c490279002
blindedpath: smarter dummy hop policy selection
This commit introduces more sophisticated code for selecting dummy hop
policy values for dummy hops in blinded paths.

For the case where the path does contain real hops, the dummy hop policy
values are derived by taking the average of those hop polices. For the
case where there are no real hops (in other words, we are the
introduction node), we use the default policy values used for normal
ChannelUpdates but then for the MaxHTLC value, we take the average of
all our open channel capacities.
2024-07-26 13:03:07 +02:00
..
autopilotrpc lnrpc: re-generate protos after dependency update 2024-03-14 09:32:29 +01:00
chainrpc multi: replace ioutil.WriteFile 2024-04-25 11:23:31 +02:00
devrpc multi: add NewLogClosure in lnutils to avoid repetition 2024-07-25 21:25:23 +08:00
invoicesrpc blindedpath: smarter dummy hop policy selection 2024-07-26 13:03:07 +02:00
lnclipb lnrpc: re-generate protos after dependency update 2024-03-14 09:32:29 +01:00
neutrinorpc lnrpc: re-generate protos after dependency update 2024-03-14 09:32:29 +01:00
peersrpc multi: enable optional route blinding feature 2024-04-26 11:35:17 -04:00
routerrpc multi: send to a blinded path in an invoice 2024-07-26 09:54:37 +02:00
signrpc multi: replace ioutil.WriteFile 2024-04-25 11:23:31 +02:00
verrpc lnrpc: re-generate protos after dependency update 2024-03-14 09:32:29 +01:00
walletrpc lnrpc: fix linter 2024-05-25 13:37:16 +08:00
watchtowerrpc lnrpc: re-generate protos after dependency update 2024-03-14 09:32:29 +01:00
wtclientrpc multi: wrap all errors 2024-04-11 15:04:03 +02:00
.clang-format make+travis: verify compiled protos on travis 2020-03-10 13:03:01 +01:00
Dockerfile multi: bump Go version 2023-09-05 10:11:42 -07:00
file_utils.go invoicesrpc: add SubscribeSingleInvoice rpc 2019-02-01 09:43:17 +01:00
gen_protos_docker.sh multi: bump Go version 2023-09-05 10:11:42 -07:00
gen_protos.sh lnrpc: identify *.proto files as separate files within a given directory 2022-12-06 12:52:31 +00:00
lightning_grpc.pb.go lnrpc: fix typo in rpc docs 2024-01-11 14:08:31 -08:00
lightning.pb.go multi: add blinded paths to invoices 2024-07-26 09:54:17 +02:00
lightning.pb.gw.go lnrpc: channel point for GetChanInfo 2024-06-06 13:28:41 +02:00
lightning.pb.json.go lnrpc+rpcserver: add new GetDebugInfo RPC method 2024-01-09 12:32:37 +01:00
lightning.proto multi: add blinded paths to invoices 2024-07-26 09:54:17 +02:00
lightning.swagger.json multi: add blinded paths to invoices 2024-07-26 09:54:17 +02:00
lightning.yaml lnrpc+rpcserver: add new GetDebugInfo RPC method 2024-01-09 12:32:37 +01:00
marshall_utils.go lnrpc+lnd+config: add coin selection strategy to all on-chain rpcs 2024-04-01 19:08:01 +02:00
metadata.go lnrpc: enable RPC middleware in REST WebSockets 2022-07-14 09:36:36 +02:00
README.md build: remove old Travis references 2024-07-25 13:14:26 -07:00
rpc_utils.go multi: rename FeePreference to FeeEstimateInfo 2024-04-19 21:33:21 +08:00
state.pb.json.go lnrpc/gen_protos.sh: remove js build tag 2022-09-07 18:32:05 -04:00
stateservice_grpc.pb.go lnrpc: update grpc-gateway library to v2 2021-07-27 13:09:59 +02:00
stateservice.pb.go lnrpc: re-generate protos after dependency update 2024-03-14 09:32:29 +01:00
stateservice.pb.gw.go lnrpc: update grpc-gateway library to v2 2021-07-27 13:09:59 +02:00
stateservice.proto Add comments for all wallet states [skip ci] 2022-09-15 09:14:36 -05:00
stateservice.swagger.json Add comments for all wallet states [skip ci] 2022-09-15 09:14:36 -05:00
stateservice.yaml lnrpc: split REST annotations into service files 2021-07-27 12:59:52 +02:00
sub_server.go lnrpc: update grpc-gateway library to v2 2021-07-27 13:09:59 +02:00
walletunlocker_grpc.pb.go lnrpc: re-compile protos w/ Go 1.19 2022-08-24 11:43:00 -05:00
walletunlocker.pb.go lnrpc: re-generate protos after dependency update 2024-03-14 09:32:29 +01:00
walletunlocker.pb.gw.go lnrpc: update grpc-gateway library to v2 2021-07-27 13:09:59 +02:00
walletunlocker.pb.json.go lnrpc/gen_protos.sh: remove js build tag 2022-09-07 18:32:05 -04:00
walletunlocker.proto protolint: configure protolint and fix the protolinting issues 2024-01-22 22:00:00 +02:00
walletunlocker.swagger.json lnrpc: add macaroon_root_key to InitWalletRequest 2022-08-12 10:30:32 -04:00
walletunlocker.yaml lnrpc: split REST annotations into service files 2021-07-27 12:59:52 +02:00
websocket_proxy.go lnrpc: increase max message size for ws proxy 2023-09-18 11:32:34 -07:00

lnrpc

MIT licensed GoDoc

This lnrpc package implements both a client and server for lnds RPC system which is based off of the high-performance cross-platform gRPC RPC framework. By default, only the Go client+server libraries are compiled within the package. In order to compile the client side libraries for other supported languages, the protoc tool will need to be used to generate the compiled protos for a specific language.

The following languages are supported as clients to lnrpc: C++, Go, Node.js, Java, Ruby, Android Java, PHP, Python, C#, Objective-C.

Service: Lightning

The list of defined RPCs on the service Lightning are the following (with a brief description):

  • WalletBalance
    • Returns the wallet's current confirmed balance in BTC.
  • ChannelBalance
    • Returns the daemons' available aggregate channel balance in BTC.
  • GetTransactions
    • Returns a list of on-chain transactions that pay to or are spends from lnd.
  • SendCoins
    • Sends an amount of satoshis to a specific address.
  • ListUnspent
    • Lists available utxos within a range of confirmations.
  • SubscribeTransactions
    • Returns a stream which sends async notifications each time a transaction is created or one is received that pays to us.
  • SendMany
    • Allows the caller to create a transaction with an arbitrary fan-out (many outputs).
  • NewAddress
    • Returns a new address, the following address types are supported: pay-to-witness-key-hash (p2wkh) and nested-pay-to-witness-key-hash (np2wkh).
  • SignMessage
    • Signs a message with the node's identity key and returns a zbase32 encoded signature.
  • VerifyMessage
    • Verifies a signature signed by another node on a message. The other node must be an active node in the channel database.
  • ConnectPeer
    • Connects to a peer identified by a public key and host.
  • DisconnectPeer
    • Disconnects a peer identified by a public key.
  • ListPeers
    • Lists all available connected peers.
  • GetInfo
    • Returns basic data concerning the daemon.
  • GetRecoveryInfo
    • Returns information about recovery process.
  • PendingChannels
    • List the number of pending (not fully confirmed) channels.
  • ListChannels
    • List all active channels the daemon manages.
  • OpenChannelSync
    • OpenChannelSync is a synchronous version of the OpenChannel RPC call.
  • OpenChannel
    • Attempts to open a channel to a target peer with a specific amount and push amount.
  • CloseChannel
    • Attempts to close a target channel. A channel can either be closed cooperatively if the channel peer is online, or using a "force" close to broadcast the latest channel state.
  • SendPayment
    • Send a payment over Lightning to a target peer.
  • SendPaymentSync
    • SendPaymentSync is the synchronous non-streaming version of SendPayment.
  • SendToRoute
    • Send a payment over Lightning to a target peer through a route explicitly defined by the user.
  • SendToRouteSync
    • SendToRouteSync is the synchronous non-streaming version of SendToRoute.
  • AddInvoice
    • Adds an invoice to the daemon. Invoices are automatically settled once seen as an incoming HTLC.
  • ListInvoices
    • Lists all stored invoices.
  • LookupInvoice
    • Attempts to look up an invoice by payment hash (r-hash).
  • SubscribeInvoices
    • Creates a uni-directional stream which receives async notifications as the daemon settles invoices
  • DecodePayReq
    • Decode a payment request, returning a full description of the conditions encoded within the payment request.
  • ListPayments
    • List all outgoing Lightning payments the daemon has made.
  • DeleteAllPayments
    • Deletes all outgoing payments from DB.
  • DescribeGraph
    • Returns a description of the known channel graph from the PoV of the node.
  • GetChanInfo
    • Returns information for a specific channel identified by channel ID.
  • GetNodeInfo
    • Returns information for a particular node identified by its identity public key.
  • QueryRoutes
    • Queries for a possible route to a target peer which can carry a certain amount of payment.
  • GetNetworkInfo
    • Returns some network level statistics.
  • StopDaemon
    • Sends a shutdown request to the interrupt handler, triggering a graceful shutdown of the daemon.
  • SubscribeChannelGraph
    • Creates a stream which receives async notifications upon any changes to the channel graph topology from the point of view of the responding node.
  • DebugLevel
    • Set logging verbosity of lnd programmatically
  • FeeReport
    • Allows the caller to obtain a report detailing the current fee schedule enforced by the node globally for each channel.
  • UpdateChannelPolicy
    • Allows the caller to update the fee schedule and channel policies for all channels globally, or a particular channel.
  • ForwardingHistory
    • ForwardingHistory allows the caller to query the htlcswitch for a record of all HTLCs forwarded.
  • BakeMacaroon
    • Bakes a new macaroon with the provided list of permissions and restrictions
  • ListMacaroonIDs
    • List all the macaroon root key IDs that are in use.
  • DeleteMacaroonID
    • Remove a specific macaroon root key ID from the database and invalidates all macaroons derived from the key with that ID.

Service: WalletUnlocker

The list of defined RPCs on the service WalletUnlocker are the following (with a brief description):

  • CreateWallet
    • Set encryption password for the wallet database.
  • UnlockWallet
    • Provide a password to unlock the wallet database.

Installation and Updating

$  go get -u github.com/lightningnetwork/lnd/lnrpc

Generate protobuf definitions

To compile the lnrpc/**/*.proto files and generate the protobuf definitions, you need to have Docker and make installed.

Simply run make rpc to start the compilation process.

Format .proto files

We use clang-format to make sure the .proto files are formatted correctly.

When running the make rpc command, the .proto files are also formatted. To format the files without also compiling them, you can install the clang-format formatter on Ubuntu by running apt install clang-format or on Mac by running brew install clang-format. The make format command should then produce the correct result.

Consult this page to find binaries for other operating systems or distributions.

Makefile commands

The following commands are available with make:

  • rpc: Compile and format all .proto files using Docker (calls lnrpc/gen_protos_docker.sh).
  • rpc-format: Formats all .proto files according to our formatting rules. Requires clang-format, see previous chapter.
  • rpc-check: Runs both previous commands and makes sure the git work tree is not dirty. This can be used to check that the .proto files are formatted and compiled properly.