fundingmanager: return ErrFundingManagerShuttingDown on shutdown

This commit is contained in:
Wilmer Paulino 2018-07-05 18:33:28 -07:00
parent 10b0df61a7
commit 8c92df0f47
No known key found for this signature in database
GPG Key ID: 6DF57B9F9514972F

@ -12,6 +12,10 @@ import (
"golang.org/x/crypto/salsa20" "golang.org/x/crypto/salsa20"
"github.com/btcsuite/btcd/btcec"
"github.com/btcsuite/btcd/chaincfg/chainhash"
"github.com/btcsuite/btcd/wire"
"github.com/btcsuite/btcutil"
"github.com/coreos/bbolt" "github.com/coreos/bbolt"
"github.com/davecgh/go-spew/spew" "github.com/davecgh/go-spew/spew"
"github.com/go-errors/errors" "github.com/go-errors/errors"
@ -23,10 +27,6 @@ import (
"github.com/lightningnetwork/lnd/lnwallet" "github.com/lightningnetwork/lnd/lnwallet"
"github.com/lightningnetwork/lnd/lnwire" "github.com/lightningnetwork/lnd/lnwire"
"github.com/lightningnetwork/lnd/routing" "github.com/lightningnetwork/lnd/routing"
"github.com/btcsuite/btcd/btcec"
"github.com/btcsuite/btcd/chaincfg/chainhash"
"github.com/btcsuite/btcd/wire"
"github.com/btcsuite/btcutil"
) )
const ( const (
@ -85,6 +85,12 @@ var (
// //
// TODO(roasbeef): add command line param to modify // TODO(roasbeef): add command line param to modify
maxFundingAmount = maxBtcFundingAmount maxFundingAmount = maxBtcFundingAmount
// ErrFundingManagerShuttingDown is an error returned when attempting to
// process a funding request/message but the funding manager has already
// been signaled to shut down.
ErrFundingManagerShuttingDown = errors.New("funding manager shutting " +
"down")
) )
// reservationWithCtx encapsulates a pending channel reservation. This wrapper // reservationWithCtx encapsulates a pending channel reservation. This wrapper
@ -740,7 +746,7 @@ func (f *fundingManager) PendingChannels() ([]*pendingChannel, error) {
select { select {
case f.queries <- req: case f.queries <- req:
case <-f.quit: case <-f.quit:
return nil, fmt.Errorf("fundingmanager shutting down") return nil, ErrFundingManagerShuttingDown
} }
select { select {
@ -749,7 +755,7 @@ func (f *fundingManager) PendingChannels() ([]*pendingChannel, error) {
case err := <-errChan: case err := <-errChan:
return nil, err return nil, err
case <-f.quit: case <-f.quit:
return nil, fmt.Errorf("fundingmanager shutting down") return nil, ErrFundingManagerShuttingDown
} }
} }
@ -1959,7 +1965,7 @@ func (f *fundingManager) sendFundingLocked(completeChan *channeldb.OpenChannel,
// Retry sending. // Retry sending.
case <-f.quit: case <-f.quit:
return fmt.Errorf("shutting down unable to send") return ErrFundingManagerShuttingDown
} }
} }
@ -2069,24 +2075,28 @@ func (f *fundingManager) annAfterSixConfs(completeChan *channeldb.OpenChannel,
confNtfn, err := f.cfg.Notifier.RegisterConfirmationsNtfn(&txid, confNtfn, err := f.cfg.Notifier.RegisterConfirmationsNtfn(&txid,
numConfs, completeChan.FundingBroadcastHeight) numConfs, completeChan.FundingBroadcastHeight)
if err != nil { if err != nil {
return fmt.Errorf("Unable to register for confirmation of "+ return fmt.Errorf("Unable to register for "+
"ChannelPoint(%v): %v", completeChan.FundingOutpoint, err) "confirmation of ChannelPoint(%v): %v",
completeChan.FundingOutpoint, err)
} }
// Wait until 6 confirmations has been reached or the wallet signals // Wait until 6 confirmations has been reached or the wallet
// a shutdown. // signals a shutdown.
select { select {
case _, ok := <-confNtfn.Confirmed: case _, ok := <-confNtfn.Confirmed:
if !ok { if !ok {
return fmt.Errorf("ChainNotifier shutting down, cannot "+ return fmt.Errorf("ChainNotifier shutting "+
"complete funding flow for ChannelPoint(%v)", "down, cannot complete funding flow "+
"for ChannelPoint(%v)",
completeChan.FundingOutpoint) completeChan.FundingOutpoint)
} }
// Fallthrough. // Fallthrough.
case <-f.quit: case <-f.quit:
return fmt.Errorf("fundingManager shutting down, stopping funding "+ return fmt.Errorf("%v, stopping funding flow for "+
"flow for ChannelPoint(%v)", completeChan.FundingOutpoint) "ChannelPoint(%v)",
ErrFundingManagerShuttingDown,
completeChan.FundingOutpoint)
} }
fundingPoint := completeChan.FundingOutpoint fundingPoint := completeChan.FundingOutpoint
@ -2095,9 +2105,10 @@ func (f *fundingManager) annAfterSixConfs(completeChan *channeldb.OpenChannel,
fndgLog.Infof("Announcing ChannelPoint(%v), short_chan_id=%v", fndgLog.Infof("Announcing ChannelPoint(%v), short_chan_id=%v",
&fundingPoint, spew.Sdump(shortChanID)) &fundingPoint, spew.Sdump(shortChanID))
// We'll obtain their min HTLC as we'll use this value within our // We'll obtain their min HTLC as we'll use this value within
// ChannelUpdate. We use this value isn't of ours, as the remote party // our ChannelUpdate. We use this value isn't of ours, as the
// will be the one that's carrying the HTLC towards us. // remote party will be the one that's carrying the HTLC towards
// us.
remoteMinHTLC := completeChan.RemoteChanCfg.MinHTLC remoteMinHTLC := completeChan.RemoteChanCfg.MinHTLC
// Create and broadcast the proofs required to make this channel // Create and broadcast the proofs required to make this channel