routing: add new PayAttemptTimeout field to LightningPayment
In this commit, we add a new field to the LightningPayment struct: PayAttemptTimeout. This new field allows the caller to control exactly how much time should be spent attempting to route a payment to the destination. The default value we’ll use is 60 seconds, but callers are able to specify a diff value. Once the timeout has passed, we’ll abandon th e payment attempt, and return an error back to the original caller.
This commit is contained in:
parent
237ed4fc6e
commit
363cec7012
@ -38,6 +38,10 @@ const (
|
|||||||
// this update can't bring us something new, or because a node
|
// this update can't bring us something new, or because a node
|
||||||
// announcement was given for node not found in any channel.
|
// announcement was given for node not found in any channel.
|
||||||
ErrIgnored
|
ErrIgnored
|
||||||
|
|
||||||
|
// ErrPaymentAttemptTimeout is an error that indicates that a payment
|
||||||
|
// attempt timed out before we were able to successfully route an HTLC.
|
||||||
|
ErrPaymentAttemptTimeout
|
||||||
)
|
)
|
||||||
|
|
||||||
// routerError is a structure that represent the error inside the routing package,
|
// routerError is a structure that represent the error inside the routing package,
|
||||||
|
@ -31,6 +31,11 @@ const (
|
|||||||
// DefaultFinalCLTVDelta is the default value to be used as the final
|
// DefaultFinalCLTVDelta is the default value to be used as the final
|
||||||
// CLTV delta for a route if one is unspecified.
|
// CLTV delta for a route if one is unspecified.
|
||||||
DefaultFinalCLTVDelta = 9
|
DefaultFinalCLTVDelta = 9
|
||||||
|
|
||||||
|
// defaultPayAttemptTimeout is a duration that we'll use to determine
|
||||||
|
// if we should give up on a payment attempt. This will be used if a
|
||||||
|
// value isn't specified in the LightningNode struct.
|
||||||
|
defaultPayAttemptTimeout = time.Duration(time.Second * 60)
|
||||||
)
|
)
|
||||||
|
|
||||||
// ChannelGraphSource represents the source of information about the topology
|
// ChannelGraphSource represents the source of information about the topology
|
||||||
@ -1453,6 +1458,12 @@ type LightningPayment struct {
|
|||||||
// used.
|
// used.
|
||||||
FinalCLTVDelta *uint16
|
FinalCLTVDelta *uint16
|
||||||
|
|
||||||
|
// PayAttemptTimeout is a timeout value that we'll use to determine
|
||||||
|
// when we should should abandon the payment attempt after consecutive
|
||||||
|
// payment failure. This prevents us from attempting to send a payment
|
||||||
|
// indefinitely.
|
||||||
|
PayAttemptTimeout time.Duration
|
||||||
|
|
||||||
// TODO(roasbeef): add e2e message?
|
// TODO(roasbeef): add e2e message?
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1490,6 +1501,15 @@ func (r *ChannelRouter) SendPayment(payment *LightningPayment) ([32]byte, *Route
|
|||||||
finalCLTVDelta = *payment.FinalCLTVDelta
|
finalCLTVDelta = *payment.FinalCLTVDelta
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var payAttemptTimeout time.Duration
|
||||||
|
if payment.PayAttemptTimeout == time.Duration(0) {
|
||||||
|
payAttemptTimeout = defaultPayAttemptTimeout
|
||||||
|
} else {
|
||||||
|
payAttemptTimeout = payment.PayAttemptTimeout
|
||||||
|
}
|
||||||
|
|
||||||
|
timeoutChan := time.After(payAttemptTimeout)
|
||||||
|
|
||||||
// Before starting the HTLC routing attempt, we'll create a fresh
|
// Before starting the HTLC routing attempt, we'll create a fresh
|
||||||
// payment session which will report our errors back to mission
|
// payment session which will report our errors back to mission
|
||||||
// control.
|
// control.
|
||||||
@ -1498,6 +1518,27 @@ func (r *ChannelRouter) SendPayment(payment *LightningPayment) ([32]byte, *Route
|
|||||||
// We'll continue until either our payment succeeds, or we encounter a
|
// We'll continue until either our payment succeeds, or we encounter a
|
||||||
// critical error during path finding.
|
// critical error during path finding.
|
||||||
for {
|
for {
|
||||||
|
// Before we attempt this next payment, we'll check to see if
|
||||||
|
// either we've gone past the payment attempt timeout, or the
|
||||||
|
// router is exiting. In either case, we'll stop this payment
|
||||||
|
// attempt short.
|
||||||
|
select {
|
||||||
|
case <-timeoutChan:
|
||||||
|
errStr := fmt.Sprintf("payment attempt not completed "+
|
||||||
|
"before timeout of %v", payAttemptTimeout)
|
||||||
|
|
||||||
|
return preImage, nil, newErr(
|
||||||
|
ErrPaymentAttemptTimeout, errStr,
|
||||||
|
)
|
||||||
|
|
||||||
|
case <-r.quit:
|
||||||
|
return preImage, nil, fmt.Errorf("router shutting down")
|
||||||
|
|
||||||
|
default:
|
||||||
|
// Fall through if we haven't hit our time limit, or
|
||||||
|
// are expiring.
|
||||||
|
}
|
||||||
|
|
||||||
// We'll kick things off by requesting a new route from mission
|
// We'll kick things off by requesting a new route from mission
|
||||||
// control, which will incorporate the current best known state
|
// control, which will incorporate the current best known state
|
||||||
// of the channel graph and our past HTLC routing
|
// of the channel graph and our past HTLC routing
|
||||||
|
Loading…
Reference in New Issue
Block a user