Merge pull request #4688 from carlaKC/4686-paymenttimeout

lncli: allow configurable timeout in send payment
This commit is contained in:
Johan T. Halseth 2020-10-13 13:06:47 +02:00 committed by GitHub
commit d26001a69a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -26,9 +26,9 @@ import (
) )
const ( const (
// paymentTimeoutSeconds is the default timeout for the payment loop in // paymentTimeout is the default timeout for the payment loop in lnd.
// lnd. No new attempts will be started after the timeout. // No new attempts will be started after the timeout.
paymentTimeoutSeconds = 60 paymentTimeout = time.Second * 60
) )
var ( var (
@ -91,6 +91,13 @@ func paymentFlags() []cli.Flag {
"the maximum fee allowed when sending the " + "the maximum fee allowed when sending the " +
"payment", "payment",
}, },
cli.DurationFlag{
Name: "timeout",
Usage: "the maximum amount of time we should spend " +
"trying to fulfill the payment, failing " +
"after the timeout has elapsed",
Value: paymentTimeout,
},
cltvLimitFlag, cltvLimitFlag,
lastHopFlag, lastHopFlag,
cli.Uint64Flag{ cli.Uint64Flag{
@ -336,7 +343,12 @@ func sendPaymentRequest(ctx *cli.Context,
} }
req.CltvLimit = int32(ctx.Int(cltvLimitFlag.Name)) req.CltvLimit = int32(ctx.Int(cltvLimitFlag.Name))
req.TimeoutSeconds = paymentTimeoutSeconds
pmtTimeout := ctx.Duration("timeout")
if pmtTimeout <= 0 {
return errors.New("payment timeout must be greater than zero")
}
req.TimeoutSeconds = int32(pmtTimeout.Seconds())
req.AllowSelfPayment = ctx.Bool("allow_self_payment") req.AllowSelfPayment = ctx.Bool("allow_self_payment")