routing: move default cltv assignment out of router
This commit lifts default setting up to the rpc server level, in line with other payment defaults.
This commit is contained in:
parent
afd86763ac
commit
19d5f8f82c
@ -222,7 +222,7 @@ func (s *Server) SendPayment(ctx context.Context,
|
|||||||
Amount: *payReq.MilliSat,
|
Amount: *payReq.MilliSat,
|
||||||
FeeLimit: lnwire.MilliSatoshi(req.FeeLimitSat),
|
FeeLimit: lnwire.MilliSatoshi(req.FeeLimitSat),
|
||||||
PaymentHash: *payReq.PaymentHash,
|
PaymentHash: *payReq.PaymentHash,
|
||||||
FinalCLTVDelta: &finalDelta,
|
FinalCLTVDelta: finalDelta,
|
||||||
PayAttemptTimeout: time.Second * time.Duration(req.TimeoutSeconds),
|
PayAttemptTimeout: time.Second * time.Duration(req.TimeoutSeconds),
|
||||||
RouteHints: payReq.RouteHints,
|
RouteHints: payReq.RouteHints,
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ func TestRequestRoute(t *testing.T) {
|
|||||||
|
|
||||||
payment := &LightningPayment{
|
payment := &LightningPayment{
|
||||||
CltvLimit: &cltvLimit,
|
CltvLimit: &cltvLimit,
|
||||||
FinalCLTVDelta: &finalCltvDelta,
|
FinalCLTVDelta: finalCltvDelta,
|
||||||
}
|
}
|
||||||
|
|
||||||
route, err := session.RequestRoute(payment, height, finalCltvDelta)
|
route, err := session.RequestRoute(payment, height, finalCltvDelta)
|
||||||
|
@ -1565,10 +1565,8 @@ type LightningPayment struct {
|
|||||||
|
|
||||||
// FinalCLTVDelta is the CTLV expiry delta to use for the _final_ hop
|
// FinalCLTVDelta is the CTLV expiry delta to use for the _final_ hop
|
||||||
// in the route. This means that the final hop will have a CLTV delta
|
// in the route. This means that the final hop will have a CLTV delta
|
||||||
// of at least: currentHeight + FinalCLTVDelta. If this value is
|
// of at least: currentHeight + FinalCLTVDelta.
|
||||||
// unspecified, then a default value of DefaultFinalCLTVDelta will be
|
FinalCLTVDelta uint16
|
||||||
// used.
|
|
||||||
FinalCLTVDelta *uint16
|
|
||||||
|
|
||||||
// PayAttemptTimeout is a timeout value that we'll use to determine
|
// PayAttemptTimeout is a timeout value that we'll use to determine
|
||||||
// when we should should abandon the payment attempt after consecutive
|
// when we should should abandon the payment attempt after consecutive
|
||||||
@ -1732,13 +1730,6 @@ func (r *ChannelRouter) sendPayment(
|
|||||||
return [32]byte{}, nil, err
|
return [32]byte{}, nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var finalCLTVDelta uint16
|
|
||||||
if payment.FinalCLTVDelta == nil {
|
|
||||||
finalCLTVDelta = zpay32.DefaultFinalCLTVDelta
|
|
||||||
} else {
|
|
||||||
finalCLTVDelta = *payment.FinalCLTVDelta
|
|
||||||
}
|
|
||||||
|
|
||||||
var payAttemptTimeout time.Duration
|
var payAttemptTimeout time.Duration
|
||||||
if payment.PayAttemptTimeout == time.Duration(0) {
|
if payment.PayAttemptTimeout == time.Duration(0) {
|
||||||
payAttemptTimeout = defaultPayAttemptTimeout
|
payAttemptTimeout = defaultPayAttemptTimeout
|
||||||
@ -1756,7 +1747,7 @@ func (r *ChannelRouter) sendPayment(
|
|||||||
paySession: paySession,
|
paySession: paySession,
|
||||||
timeoutChan: timeoutChan,
|
timeoutChan: timeoutChan,
|
||||||
currentHeight: currentHeight,
|
currentHeight: currentHeight,
|
||||||
finalCLTVDelta: finalCLTVDelta,
|
finalCLTVDelta: uint16(payment.FinalCLTVDelta),
|
||||||
attempt: existingAttempt,
|
attempt: existingAttempt,
|
||||||
circuit: nil,
|
circuit: nil,
|
||||||
lastError: nil,
|
lastError: nil,
|
||||||
|
11
rpcserver.go
11
rpcserver.go
@ -2998,7 +2998,11 @@ func extractPaymentIntent(rpcPayReq *rpcPaymentRequest) (rpcPaymentIntent, error
|
|||||||
rpcPayReq.FeeLimit, payIntent.msat,
|
rpcPayReq.FeeLimit, payIntent.msat,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if rpcPayReq.FinalCltvDelta != 0 {
|
||||||
payIntent.cltvDelta = uint16(rpcPayReq.FinalCltvDelta)
|
payIntent.cltvDelta = uint16(rpcPayReq.FinalCltvDelta)
|
||||||
|
} else {
|
||||||
|
payIntent.cltvDelta = zpay32.DefaultFinalCLTVDelta
|
||||||
|
}
|
||||||
|
|
||||||
// If the user is manually specifying payment details, then the payment
|
// If the user is manually specifying payment details, then the payment
|
||||||
// hash may be encoded as a string.
|
// hash may be encoded as a string.
|
||||||
@ -3069,6 +3073,7 @@ func (r *rpcServer) dispatchPaymentIntent(
|
|||||||
payment := &routing.LightningPayment{
|
payment := &routing.LightningPayment{
|
||||||
Target: payIntent.dest,
|
Target: payIntent.dest,
|
||||||
Amount: payIntent.msat,
|
Amount: payIntent.msat,
|
||||||
|
FinalCLTVDelta: payIntent.cltvDelta,
|
||||||
FeeLimit: payIntent.feeLimit,
|
FeeLimit: payIntent.feeLimit,
|
||||||
CltvLimit: payIntent.cltvLimit,
|
CltvLimit: payIntent.cltvLimit,
|
||||||
PaymentHash: payIntent.rHash,
|
PaymentHash: payIntent.rHash,
|
||||||
@ -3077,12 +3082,6 @@ func (r *rpcServer) dispatchPaymentIntent(
|
|||||||
PaymentRequest: payIntent.payReq,
|
PaymentRequest: payIntent.payReq,
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the final CLTV value was specified, then we'll use that
|
|
||||||
// rather than the default.
|
|
||||||
if payIntent.cltvDelta != 0 {
|
|
||||||
payment.FinalCLTVDelta = &payIntent.cltvDelta
|
|
||||||
}
|
|
||||||
|
|
||||||
preImage, route, routerErr = r.server.chanRouter.SendPayment(
|
preImage, route, routerErr = r.server.chanRouter.SendPayment(
|
||||||
payment,
|
payment,
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user