2018-10-23 07:43:47 +03:00
|
|
|
syntax = "proto3";
|
|
|
|
|
2019-03-14 18:31:39 +03:00
|
|
|
import "rpc.proto";
|
|
|
|
|
2018-10-23 07:43:47 +03:00
|
|
|
package routerrpc;
|
|
|
|
|
2019-03-14 18:31:39 +03:00
|
|
|
option go_package = "github.com/lightningnetwork/lnd/lnrpc/routerrpc";
|
|
|
|
|
2019-03-22 12:21:25 +03:00
|
|
|
message SendPaymentRequest {
|
2019-04-18 10:34:28 +03:00
|
|
|
/// The identity pubkey of the payment recipient
|
|
|
|
bytes dest = 1;
|
2018-10-23 07:43:47 +03:00
|
|
|
|
2019-11-11 18:44:08 +03:00
|
|
|
/**
|
|
|
|
Number of satoshis to send.
|
|
|
|
|
|
|
|
The fields amt and amt_msat are mutually exclusive.
|
|
|
|
*/
|
2019-04-18 10:34:28 +03:00
|
|
|
int64 amt = 2;
|
|
|
|
|
2019-11-11 18:44:08 +03:00
|
|
|
/**
|
|
|
|
Number of millisatoshis to send.
|
2020-03-02 17:35:25 +03:00
|
|
|
|
2019-11-11 18:44:08 +03:00
|
|
|
The fields amt and amt_msat are mutually exclusive.
|
|
|
|
*/
|
|
|
|
int64 amt_msat = 12;
|
|
|
|
|
2019-04-18 10:34:28 +03:00
|
|
|
/// The hash to use within the payment's HTLC
|
|
|
|
bytes payment_hash = 3;
|
2020-02-11 15:58:45 +03:00
|
|
|
|
2018-10-23 07:43:47 +03:00
|
|
|
/**
|
2019-04-18 10:34:28 +03:00
|
|
|
The CLTV delta from the current height that should be used to set the
|
|
|
|
timelock for the final hop.
|
2018-10-23 07:43:47 +03:00
|
|
|
*/
|
2019-04-18 10:34:28 +03:00
|
|
|
int32 final_cltv_delta = 4;
|
2018-10-23 07:43:47 +03:00
|
|
|
|
|
|
|
/**
|
2019-04-18 10:34:28 +03:00
|
|
|
A bare-bones invoice for a payment within the Lightning Network. With the
|
|
|
|
details of the invoice, the sender has all the data necessary to send a
|
|
|
|
payment to the recipient. The amount in the payment request may be zero. In
|
|
|
|
that case it is required to set the amt field as well. If no payment request
|
|
|
|
is specified, the following fields are required: dest, amt and payment_hash.
|
2018-10-23 07:43:47 +03:00
|
|
|
*/
|
2019-04-18 10:34:28 +03:00
|
|
|
string payment_request = 5;
|
2018-10-23 07:43:47 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
An upper limit on the amount of time we should spend when attempting to
|
|
|
|
fulfill the payment. This is expressed in seconds. If we cannot make a
|
|
|
|
successful payment within this time frame, an error will be returned.
|
2019-04-18 10:34:28 +03:00
|
|
|
This field must be non-zero.
|
|
|
|
*/
|
|
|
|
int32 timeout_seconds = 6;
|
|
|
|
|
|
|
|
/**
|
|
|
|
The maximum number of satoshis that will be paid as a fee of the payment.
|
|
|
|
If this field is left to the default value of 0, only zero-fee routes will
|
|
|
|
be considered. This usually means single hop routes connecting directly to
|
|
|
|
the destination. To send the payment without a fee limit, use max int here.
|
2019-11-11 18:44:08 +03:00
|
|
|
|
|
|
|
The fields fee_limit_sat and fee_limit_msat are mutually exclusive.
|
2018-10-23 07:43:47 +03:00
|
|
|
*/
|
2019-04-18 10:34:28 +03:00
|
|
|
int64 fee_limit_sat = 7;
|
2018-10-23 07:43:47 +03:00
|
|
|
|
2020-02-11 15:58:45 +03:00
|
|
|
/**
|
2020-03-02 17:35:25 +03:00
|
|
|
The maximum number of millisatoshis that will be paid as a fee of the
|
|
|
|
payment. If this field is left to the default value of 0, only zero-fee
|
|
|
|
routes will be considered. This usually means single hop routes connecting
|
|
|
|
directly to the destination. To send the payment without a fee limit, use
|
|
|
|
max int here.
|
|
|
|
|
|
|
|
The fields fee_limit_sat and fee_limit_msat are mutually exclusive.
|
|
|
|
*/
|
2019-11-11 18:44:08 +03:00
|
|
|
int64 fee_limit_msat = 13;
|
|
|
|
|
2018-10-23 07:43:47 +03:00
|
|
|
/**
|
|
|
|
The channel id of the channel that must be taken to the first hop. If zero,
|
|
|
|
any channel may be used.
|
|
|
|
*/
|
2018-12-19 23:49:41 +03:00
|
|
|
uint64 outgoing_chan_id = 8 [jstype = JS_STRING];
|
2019-04-18 10:34:28 +03:00
|
|
|
|
2019-11-18 14:08:42 +03:00
|
|
|
/**
|
|
|
|
The pubkey of the last hop of the route. If empty, any hop may be used.
|
|
|
|
*/
|
|
|
|
bytes last_hop_pubkey = 14;
|
|
|
|
|
2020-03-02 17:35:25 +03:00
|
|
|
/**
|
2019-10-11 22:46:10 +03:00
|
|
|
An optional maximum total time lock for the route. This should not exceed
|
|
|
|
lnd's `--max-cltv-expiry` setting. If zero, then the value of
|
|
|
|
`--max-cltv-expiry` is enforced.
|
2019-04-18 10:34:28 +03:00
|
|
|
*/
|
|
|
|
int32 cltv_limit = 9;
|
2019-06-18 11:36:29 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
Optional route hints to reach the destination through private channels.
|
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
repeated lnrpc.RouteHint route_hints = 10;
|
2019-07-31 07:44:02 +03:00
|
|
|
|
2020-03-02 17:35:25 +03:00
|
|
|
/**
|
2019-07-31 07:44:02 +03:00
|
|
|
An optional field that can be used to pass an arbitrary set of TLV records
|
|
|
|
to a peer which understands the new records. This can be used to pass
|
2019-11-20 14:00:25 +03:00
|
|
|
application specific data during the payment attempt. Record types are
|
|
|
|
required to be in the custom range >= 65536. When using REST, the values
|
|
|
|
must be encoded as base64.
|
2019-07-31 07:44:02 +03:00
|
|
|
*/
|
2019-11-20 14:00:25 +03:00
|
|
|
map<uint64, bytes> dest_custom_records = 11;
|
2019-11-25 16:13:21 +03:00
|
|
|
|
|
|
|
/// If set, circular payments to self are permitted.
|
|
|
|
bool allow_self_payment = 15;
|
2019-12-19 10:57:23 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
Features assumed to be supported by the final node. All transitive feature
|
2020-01-18 00:12:02 +03:00
|
|
|
dependencies must also be set properly. For a given feature bit pair, either
|
2019-12-20 03:25:59 +03:00
|
|
|
optional or remote may be set, but not both. If this field is nil or empty,
|
|
|
|
the router will try to load destination features from the graph as a
|
|
|
|
fallback.
|
2019-12-19 10:57:23 +03:00
|
|
|
*/
|
|
|
|
repeated lnrpc.FeatureBit dest_features = 16;
|
2018-10-23 07:43:47 +03:00
|
|
|
}
|
|
|
|
|
2019-03-22 12:21:25 +03:00
|
|
|
message TrackPaymentRequest {
|
|
|
|
/// The hash of the payment to look up.
|
|
|
|
bytes payment_hash = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
enum PaymentState {
|
|
|
|
/**
|
|
|
|
Payment is still in flight.
|
|
|
|
*/
|
|
|
|
IN_FLIGHT = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Payment completed successfully.
|
|
|
|
*/
|
|
|
|
SUCCEEDED = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
There are more routes to try, but the payment timeout was exceeded.
|
|
|
|
*/
|
|
|
|
FAILED_TIMEOUT = 2;
|
2020-02-11 15:58:45 +03:00
|
|
|
|
2018-10-23 07:43:47 +03:00
|
|
|
/**
|
2019-03-22 12:21:25 +03:00
|
|
|
All possible routes were tried and failed permanently. Or were no
|
|
|
|
routes to the destination at all.
|
2018-10-23 07:43:47 +03:00
|
|
|
*/
|
2019-03-22 12:21:25 +03:00
|
|
|
FAILED_NO_ROUTE = 3;
|
2019-06-04 12:22:23 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
A non-recoverable error has occured.
|
|
|
|
*/
|
|
|
|
FAILED_ERROR = 4;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Payment details incorrect (unknown hash, invalid amt or
|
|
|
|
invalid final cltv delta)
|
|
|
|
*/
|
|
|
|
FAILED_INCORRECT_PAYMENT_DETAILS = 5;
|
2019-11-21 13:59:17 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
Insufficient local balance.
|
|
|
|
*/
|
|
|
|
FAILED_INSUFFICIENT_BALANCE = 6;
|
2019-03-22 12:21:25 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
message PaymentStatus {
|
|
|
|
/// Current state the payment is in.
|
|
|
|
PaymentState state = 1;
|
2018-10-23 07:43:47 +03:00
|
|
|
|
|
|
|
/**
|
2019-03-22 12:21:25 +03:00
|
|
|
The pre-image of the payment when state is SUCCEEDED.
|
2018-10-23 07:43:47 +03:00
|
|
|
*/
|
2019-03-22 12:21:25 +03:00
|
|
|
bytes preimage = 2;
|
2018-10-23 07:43:47 +03:00
|
|
|
|
|
|
|
/**
|
2019-03-22 12:21:25 +03:00
|
|
|
The taken route when state is SUCCEEDED.
|
2018-10-23 07:43:47 +03:00
|
|
|
*/
|
2019-03-22 12:21:25 +03:00
|
|
|
lnrpc.Route route = 3;
|
2019-11-20 07:42:38 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
The HTLCs made in attempt to settle the payment [EXPERIMENTAL].
|
|
|
|
*/
|
|
|
|
repeated lnrpc.HTLCAttempt htlcs = 4;
|
2018-10-23 07:43:47 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
message RouteFeeRequest {
|
|
|
|
/**
|
|
|
|
The destination once wishes to obtain a routing fee quote to.
|
|
|
|
*/
|
|
|
|
bytes dest = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
The amount one wishes to send to the target destination.
|
|
|
|
*/
|
|
|
|
int64 amt_sat = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message RouteFeeResponse {
|
|
|
|
/**
|
|
|
|
A lower bound of the estimated fee to the target destination within the
|
|
|
|
network, expressed in milli-satoshis.
|
|
|
|
*/
|
|
|
|
int64 routing_fee_msat = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
An estimate of the worst case time delay that can occur. Note that callers
|
|
|
|
will still need to factor in the final CLTV delta of the last hop into this
|
|
|
|
value.
|
|
|
|
*/
|
|
|
|
int64 time_lock_delay = 2;
|
|
|
|
}
|
|
|
|
|
2019-03-14 18:31:39 +03:00
|
|
|
message SendToRouteRequest {
|
|
|
|
/// The payment hash to use for the HTLC.
|
|
|
|
bytes payment_hash = 1;
|
|
|
|
|
|
|
|
/// Route that should be used to attempt to complete the payment.
|
|
|
|
lnrpc.Route route = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message SendToRouteResponse {
|
|
|
|
/// The preimage obtained by making the payment.
|
|
|
|
bytes preimage = 1;
|
|
|
|
|
|
|
|
/// The failure message in case the payment failed.
|
2020-02-13 13:40:51 +03:00
|
|
|
lnrpc.Failure failure = 2;
|
2019-03-14 18:31:39 +03:00
|
|
|
}
|
|
|
|
|
2020-02-11 15:58:45 +03:00
|
|
|
message ResetMissionControlRequest {
|
|
|
|
}
|
2019-05-10 19:00:15 +03:00
|
|
|
|
2020-02-11 15:58:45 +03:00
|
|
|
message ResetMissionControlResponse {
|
|
|
|
}
|
2019-03-14 18:31:39 +03:00
|
|
|
|
2020-02-11 15:58:45 +03:00
|
|
|
message QueryMissionControlRequest {
|
|
|
|
}
|
2019-05-10 11:38:31 +03:00
|
|
|
|
2019-07-29 16:10:58 +03:00
|
|
|
/// QueryMissionControlResponse contains mission control state.
|
2019-05-10 11:38:31 +03:00
|
|
|
message QueryMissionControlResponse {
|
2019-09-27 12:19:30 +03:00
|
|
|
reserved 1;
|
2019-07-29 16:10:58 +03:00
|
|
|
|
|
|
|
/// Node pair-level mission control state.
|
2020-02-11 15:58:45 +03:00
|
|
|
repeated PairHistory pairs = 2;
|
2019-05-10 11:38:31 +03:00
|
|
|
}
|
|
|
|
|
2019-07-29 16:10:58 +03:00
|
|
|
/// PairHistory contains the mission control state for a particular node pair.
|
|
|
|
message PairHistory {
|
|
|
|
/// The source node pubkey of the pair.
|
2020-02-11 15:58:45 +03:00
|
|
|
bytes node_from = 1;
|
|
|
|
|
2019-07-29 16:10:58 +03:00
|
|
|
/// The destination node pubkey of the pair.
|
2020-02-11 15:58:45 +03:00
|
|
|
bytes node_to = 2;
|
2019-09-30 10:12:50 +03:00
|
|
|
|
|
|
|
reserved 3, 4, 5, 6;
|
|
|
|
|
2020-02-11 15:58:45 +03:00
|
|
|
PairData history = 7;
|
2019-09-30 10:12:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
message PairData {
|
2019-09-26 18:04:02 +03:00
|
|
|
/// Time of last failure.
|
2020-02-11 15:58:45 +03:00
|
|
|
int64 fail_time = 1;
|
2019-05-10 11:38:31 +03:00
|
|
|
|
2019-09-26 18:04:02 +03:00
|
|
|
/**
|
|
|
|
Lowest amount that failed to forward rounded to whole sats. This may be
|
|
|
|
set to zero if the failure is independent of amount.
|
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
int64 fail_amt_sat = 2;
|
2019-09-26 18:04:02 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
Lowest amount that failed to forward in millisats. This may be
|
|
|
|
set to zero if the failure is independent of amount.
|
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
int64 fail_amt_msat = 4;
|
2019-09-26 18:04:02 +03:00
|
|
|
|
|
|
|
reserved 3;
|
|
|
|
|
|
|
|
/// Time of last success.
|
2020-02-11 15:58:45 +03:00
|
|
|
int64 success_time = 5;
|
2019-09-26 17:33:08 +03:00
|
|
|
|
2019-09-26 18:04:02 +03:00
|
|
|
/// Highest amount that we could successfully forward rounded to whole sats.
|
2020-02-11 15:58:45 +03:00
|
|
|
int64 success_amt_sat = 6;
|
2019-07-29 15:20:06 +03:00
|
|
|
|
2019-09-26 18:04:02 +03:00
|
|
|
/// Highest amount that we could successfully forward in millisats.
|
2020-02-11 15:58:45 +03:00
|
|
|
int64 success_amt_msat = 7;
|
2019-05-10 11:38:31 +03:00
|
|
|
}
|
|
|
|
|
2020-02-11 15:58:45 +03:00
|
|
|
message QueryProbabilityRequest {
|
2019-09-27 12:43:12 +03:00
|
|
|
/// The source node pubkey of the pair.
|
2020-02-11 15:58:45 +03:00
|
|
|
bytes from_node = 1;
|
2019-09-27 12:43:12 +03:00
|
|
|
|
|
|
|
/// The destination node pubkey of the pair.
|
2020-02-11 15:58:45 +03:00
|
|
|
bytes to_node = 2;
|
2019-09-27 12:43:12 +03:00
|
|
|
|
|
|
|
/// The amount for which to calculate a probability.
|
2020-02-11 15:58:45 +03:00
|
|
|
int64 amt_msat = 3;
|
2019-09-27 12:43:12 +03:00
|
|
|
}
|
|
|
|
|
2020-02-11 15:58:45 +03:00
|
|
|
message QueryProbabilityResponse {
|
2019-09-27 12:43:12 +03:00
|
|
|
/// The success probability for the requested pair.
|
2020-02-11 15:58:45 +03:00
|
|
|
double probability = 1;
|
2019-09-27 12:43:12 +03:00
|
|
|
|
|
|
|
/// The historical data for the requested pair.
|
2020-02-11 15:58:45 +03:00
|
|
|
PairData history = 2;
|
2019-09-27 12:43:12 +03:00
|
|
|
}
|
|
|
|
|
2019-08-29 14:03:37 +03:00
|
|
|
message BuildRouteRequest {
|
|
|
|
/**
|
|
|
|
The amount to send expressed in msat. If set to zero, the minimum routable
|
|
|
|
amount is used.
|
|
|
|
*/
|
|
|
|
int64 amt_msat = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
CLTV delta from the current height that should be used for the timelock
|
|
|
|
of the final hop
|
|
|
|
*/
|
|
|
|
int32 final_cltv_delta = 2;
|
|
|
|
|
|
|
|
/**
|
|
|
|
The channel id of the channel that must be taken to the first hop. If zero,
|
|
|
|
any channel may be used.
|
|
|
|
*/
|
2018-12-19 23:49:41 +03:00
|
|
|
uint64 outgoing_chan_id = 3 [jstype = JS_STRING];
|
2019-08-29 14:03:37 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
A list of hops that defines the route. This does not include the source hop
|
|
|
|
pubkey.
|
|
|
|
*/
|
|
|
|
repeated bytes hop_pubkeys = 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
message BuildRouteResponse {
|
|
|
|
/**
|
|
|
|
Fully specified route that can be used to execute the payment.
|
|
|
|
*/
|
|
|
|
lnrpc.Route route = 1;
|
|
|
|
}
|
|
|
|
|
2018-10-23 07:43:47 +03:00
|
|
|
service Router {
|
|
|
|
/**
|
|
|
|
SendPayment attempts to route a payment described by the passed
|
2019-03-22 12:21:25 +03:00
|
|
|
PaymentRequest to the final destination. The call returns a stream of
|
|
|
|
payment status updates.
|
2018-10-23 07:43:47 +03:00
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
rpc SendPayment (SendPaymentRequest) returns (stream PaymentStatus);
|
2019-03-22 12:21:25 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
TrackPayment returns an update stream for the payment identified by the
|
|
|
|
payment hash.
|
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
rpc TrackPayment (TrackPaymentRequest) returns (stream PaymentStatus);
|
2018-10-23 07:43:47 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
EstimateRouteFee allows callers to obtain a lower bound w.r.t how much it
|
|
|
|
may cost to send an HTLC to the target end destination.
|
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
rpc EstimateRouteFee (RouteFeeRequest) returns (RouteFeeResponse);
|
2019-03-14 18:31:39 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
SendToRoute attempts to make a payment via the specified route. This method
|
|
|
|
differs from SendPayment in that it allows users to specify a full route
|
|
|
|
manually. This can be used for things like rebalancing, and atomic swaps.
|
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
rpc SendToRoute (SendToRouteRequest) returns (SendToRouteResponse);
|
2019-05-10 19:00:15 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
ResetMissionControl clears all mission control state and starts with a clean
|
|
|
|
slate.
|
|
|
|
*/
|
2020-03-02 17:35:25 +03:00
|
|
|
rpc ResetMissionControl (ResetMissionControlRequest)
|
|
|
|
returns (ResetMissionControlResponse);
|
2020-02-11 15:58:45 +03:00
|
|
|
|
2019-05-10 11:38:31 +03:00
|
|
|
/**
|
|
|
|
QueryMissionControl exposes the internal mission control state to callers.
|
|
|
|
It is a development feature.
|
|
|
|
*/
|
2020-03-02 17:35:25 +03:00
|
|
|
rpc QueryMissionControl (QueryMissionControlRequest)
|
|
|
|
returns (QueryMissionControlResponse);
|
2019-08-29 14:03:37 +03:00
|
|
|
|
2019-09-27 12:43:12 +03:00
|
|
|
/**
|
|
|
|
QueryProbability returns the current success probability estimate for a
|
|
|
|
given node pair and amount.
|
|
|
|
*/
|
2020-03-02 17:35:25 +03:00
|
|
|
rpc QueryProbability (QueryProbabilityRequest)
|
|
|
|
returns (QueryProbabilityResponse);
|
2019-09-27 12:43:12 +03:00
|
|
|
|
2019-08-29 14:03:37 +03:00
|
|
|
/**
|
|
|
|
BuildRoute builds a fully specified route based on a list of hop public
|
|
|
|
keys. It retrieves the relevant channel policies from the graph in order to
|
|
|
|
calculate the correct fees and time locks.
|
|
|
|
*/
|
2020-02-11 15:58:45 +03:00
|
|
|
rpc BuildRoute (BuildRouteRequest) returns (BuildRouteResponse);
|
2018-10-23 07:43:47 +03:00
|
|
|
}
|