routing: label payment lifecycle loop

This commit is contained in:
carla 2021-04-23 08:51:07 +02:00
parent a63640c488
commit b43ddfdb11
No known key found for this signature in database
GPG Key ID: 4CA7FE54A6213C91

@ -115,6 +115,7 @@ func (p *paymentLifecycle) resumePayment() ([32]byte, *route.Route, error) {
// 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.
lifecycle:
for { for {
// Start by quickly checking if there are any outcomes already // Start by quickly checking if there are any outcomes already
// available to handle before we reevaluate our state. // available to handle before we reevaluate our state.
@ -171,7 +172,7 @@ func (p *paymentLifecycle) resumePayment() ([32]byte, *route.Route, error) {
if err := shardHandler.waitForShard(); err != nil { if err := shardHandler.waitForShard(); err != nil {
return [32]byte{}, nil, err return [32]byte{}, nil, err
} }
continue continue lifecycle
} }
// Before we attempt any new shard, we'll check to see if // Before we attempt any new shard, we'll check to see if
@ -195,7 +196,7 @@ func (p *paymentLifecycle) resumePayment() ([32]byte, *route.Route, error) {
return [32]byte{}, nil, saveErr return [32]byte{}, nil, saveErr
} }
continue continue lifecycle
case <-p.router.quit: case <-p.router.quit:
return [32]byte{}, nil, ErrRouterShuttingDown return [32]byte{}, nil, ErrRouterShuttingDown
@ -234,7 +235,7 @@ func (p *paymentLifecycle) resumePayment() ([32]byte, *route.Route, error) {
return [32]byte{}, nil, saveErr return [32]byte{}, nil, saveErr
} }
continue continue lifecycle
} }
// We still have active shards, we'll wait for an // We still have active shards, we'll wait for an
@ -242,7 +243,7 @@ func (p *paymentLifecycle) resumePayment() ([32]byte, *route.Route, error) {
if err := shardHandler.waitForShard(); err != nil { if err := shardHandler.waitForShard(); err != nil {
return [32]byte{}, nil, err return [32]byte{}, nil, err
} }
continue continue lifecycle
} }
// We found a route to try, launch a new shard. // We found a route to try, launch a new shard.
@ -256,7 +257,7 @@ func (p *paymentLifecycle) resumePayment() ([32]byte, *route.Route, error) {
log.Infof("Payment: %v in terminal state, abandoning "+ log.Infof("Payment: %v in terminal state, abandoning "+
"shard", p.paymentHash) "shard", p.paymentHash)
continue continue lifecycle
case err != nil: case err != nil:
return [32]byte{}, nil, err return [32]byte{}, nil, err
@ -281,7 +282,7 @@ func (p *paymentLifecycle) resumePayment() ([32]byte, *route.Route, error) {
// Error was handled successfully, continue to make a // Error was handled successfully, continue to make a
// new attempt. // new attempt.
continue continue lifecycle
} }
// Now that the shard was successfully sent, launch a go // Now that the shard was successfully sent, launch a go