fundingmanager: return ErrFundingManagerShuttingDown on shutdown
This commit is contained in:
parent
10b0df61a7
commit
8c92df0f47
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user