htlcswitch: update to use new event stream from the chainWatcher

This commit is contained in:
Olaoluwa Osuntokun 2018-01-18 14:15:42 -08:00
parent 69e6ec9954
commit 239416f242
No known key found for this signature in database
GPG Key ID: 964EA263DD637C21
5 changed files with 31 additions and 27 deletions

@ -135,6 +135,11 @@ type ChannelLinkConfig struct {
// been closed, or when the set of active HTLC's is updated. // been closed, or when the set of active HTLC's is updated.
UpdateContractSignals func(*contractcourt.ContractSignals) error UpdateContractSignals func(*contractcourt.ContractSignals) error
// ChainEvents is an active subscription to the chain watcher for this
// channel to be notified of any on-chain activity related to this
// channel.
ChainEvents *contractcourt.ChainEventSubscription
// FeeEstimator is an instance of a live fee estimator which will be // FeeEstimator is an instance of a live fee estimator which will be
// used to dynamically regulate the current fee of the commitment // used to dynamically regulate the current fee of the commitment
// transaction to ensure timely confirmation. // transaction to ensure timely confirmation.
@ -285,9 +290,8 @@ func (l *channelLink) Start() error {
// Before we start the link, we'll update the ChainArbitrator with the // Before we start the link, we'll update the ChainArbitrator with the
// set of new channel signals for this channel. // set of new channel signals for this channel.
if err := l.cfg.UpdateContractSignals(&contractcourt.ContractSignals{ if err := l.cfg.UpdateContractSignals(&contractcourt.ContractSignals{
HtlcUpdates: l.htlcUpdates, HtlcUpdates: l.htlcUpdates,
UniCloseSignal: l.channel.UnilateralClose, ShortChanID: l.channel.ShortChanID(),
ShortChanID: l.channel.ShortChanID(),
}); err != nil { }); err != nil {
return err return err
} }
@ -313,6 +317,10 @@ func (l *channelLink) Stop() {
log.Infof("ChannelLink(%v) is stopping", l) log.Infof("ChannelLink(%v) is stopping", l)
if l.cfg.ChainEvents.Cancel != nil {
l.cfg.ChainEvents.Cancel()
}
l.channel.Stop() l.channel.Stop()
l.mailBox.Stop() l.mailBox.Stop()
@ -631,10 +639,12 @@ out:
// carried out by the remote peer. In the case of such an // carried out by the remote peer. In the case of such an
// event, we'll wipe the channel state from the peer, and mark // event, we'll wipe the channel state from the peer, and mark
// the contract as fully settled. Afterwards we can exit. // the contract as fully settled. Afterwards we can exit.
case <-l.channel.UnilateralCloseSignal: case <-l.cfg.ChainEvents.UnilateralClosure:
log.Warnf("Remote peer has closed ChannelPoint(%v) on-chain", log.Warnf("Remote peer has closed ChannelPoint(%v) on-chain",
l.channel.ChannelPoint()) l.channel.ChannelPoint())
// TODO(roasbeef): move this and above to chainJanitor
// TODO(roasbeef): remove all together // TODO(roasbeef): remove all together
go func() { go func() {
chanPoint := l.channel.ChannelPoint() chanPoint := l.channel.ChannelPoint()
@ -649,17 +659,6 @@ out:
break out break out
// A local sub-system has initiated a force close of the active
// channel. In this case we can exit immediately as no further
// updates should be processed for the channel.
case <-l.channel.ForceCloseSignal:
// TODO(roasbeef): path never taken now that server
// force closes's directly?
log.Warnf("ChannelPoint(%v) has been force "+
"closed, disconnecting from peer(%x)",
l.channel.ChannelPoint(), l.cfg.Peer.PubKey())
break out
case <-l.logCommitTick: case <-l.logCommitTick:
// If we haven't sent or received a new commitment // If we haven't sent or received a new commitment
// update in some time, check to see if we have any // update in some time, check to see if we have any

@ -1465,6 +1465,7 @@ func newSingleLinkTestHarness(chanAmt btcutil.Amount) (ChannelLink, func(), erro
return nil return nil
}, },
Registry: invoiveRegistry, Registry: invoiveRegistry,
ChainEvents: &contractcourt.ChainEventSubscription{},
BlockEpochs: globalEpoch, BlockEpochs: globalEpoch,
} }

@ -268,13 +268,13 @@ func createTestChannel(alicePrivKey, bobPrivKey []byte,
} }
channelAlice, err := lnwallet.NewLightningChannel( channelAlice, err := lnwallet.NewLightningChannel(
aliceSigner, nil, pCache, aliceChannelState, aliceSigner, pCache, aliceChannelState,
) )
if err != nil { if err != nil {
return nil, nil, nil, nil, err return nil, nil, nil, nil, err
} }
channelBob, err := lnwallet.NewLightningChannel( channelBob, err := lnwallet.NewLightningChannel(
bobSigner, nil, pCache, bobChannelState, bobSigner, pCache, bobChannelState,
) )
if err != nil { if err != nil {
return nil, nil, nil, nil, err return nil, nil, nil, nil, err
@ -319,7 +319,7 @@ func createTestChannel(alicePrivKey, bobPrivKey []byte,
} }
newAliceChannel, err := lnwallet.NewLightningChannel(aliceSigner, newAliceChannel, err := lnwallet.NewLightningChannel(aliceSigner,
nil, nil, aliceStoredChannel) nil, aliceStoredChannel)
if err != nil { if err != nil {
return nil, nil, errors.Errorf("unable to create new channel: %v", return nil, nil, errors.Errorf("unable to create new channel: %v",
err) err)
@ -343,7 +343,7 @@ func createTestChannel(alicePrivKey, bobPrivKey []byte,
return nil, nil, errors.New("unable to find stored bob channel") return nil, nil, errors.New("unable to find stored bob channel")
} }
newBobChannel, err := lnwallet.NewLightningChannel(bobSigner, nil, newBobChannel, err := lnwallet.NewLightningChannel(bobSigner,
nil, bobStoredChannel) nil, bobStoredChannel)
if err != nil { if err != nil {
return nil, nil, errors.Errorf("unable to create new channel: %v", return nil, nil, errors.Errorf("unable to create new channel: %v",
@ -761,7 +761,8 @@ func newThreeHopNetwork(t testing.TB, aliceChannel, firstBobChannel,
UpdateContractSignals: func(*contractcourt.ContractSignals) error { UpdateContractSignals: func(*contractcourt.ContractSignals) error {
return nil return nil
}, },
SyncStates: true, ChainEvents: &contractcourt.ChainEventSubscription{},
SyncStates: true,
}, },
aliceChannel, aliceChannel,
startingHeight, startingHeight,
@ -799,7 +800,8 @@ func newThreeHopNetwork(t testing.TB, aliceChannel, firstBobChannel,
UpdateContractSignals: func(*contractcourt.ContractSignals) error { UpdateContractSignals: func(*contractcourt.ContractSignals) error {
return nil return nil
}, },
SyncStates: true, ChainEvents: &contractcourt.ChainEventSubscription{},
SyncStates: true,
}, },
firstBobChannel, firstBobChannel,
startingHeight, startingHeight,
@ -837,7 +839,8 @@ func newThreeHopNetwork(t testing.TB, aliceChannel, firstBobChannel,
UpdateContractSignals: func(*contractcourt.ContractSignals) error { UpdateContractSignals: func(*contractcourt.ContractSignals) error {
return nil return nil
}, },
SyncStates: true, ChainEvents: &contractcourt.ChainEventSubscription{},
SyncStates: true,
}, },
secondBobChannel, secondBobChannel,
startingHeight, startingHeight,
@ -875,7 +878,8 @@ func newThreeHopNetwork(t testing.TB, aliceChannel, firstBobChannel,
UpdateContractSignals: func(*contractcourt.ContractSignals) error { UpdateContractSignals: func(*contractcourt.ContractSignals) error {
return nil return nil
}, },
SyncStates: true, ChainEvents: &contractcourt.ChainEventSubscription{},
SyncStates: true,
}, },
carolChannel, carolChannel,
startingHeight, startingHeight,

@ -400,7 +400,7 @@ func (ns *nurseryStore) CribToKinder(bby *babyOutput) error {
return err return err
} }
utxnLog.Tracef("Placing (crib -> baby) output for "+ utxnLog.Tracef("Transitioning (crib -> baby) output for "+
"chan_point=%v at height_index=%v", chanPoint, "chan_point=%v at height_index=%v", chanPoint,
maturityHeight) maturityHeight)
@ -494,7 +494,7 @@ func (ns *nurseryStore) PreschoolToKinder(kid *kidOutput) error {
maturityHeight = lastGradHeight + 1 maturityHeight = lastGradHeight + 1
} }
utxnLog.Tracef("Placing (crib -> kid) output for "+ utxnLog.Infof("Transitioning (crib -> kid) output for "+
"chan_point=%v at height_index=%v", chanPoint, "chan_point=%v at height_index=%v", chanPoint,
maturityHeight) maturityHeight)

@ -222,13 +222,13 @@ func createTestPeer(notifier chainntnfs.ChainNotifier,
bobSigner := &mockSigner{bobKeyPriv} bobSigner := &mockSigner{bobKeyPriv}
channelAlice, err := lnwallet.NewLightningChannel( channelAlice, err := lnwallet.NewLightningChannel(
aliceSigner, notifier, nil, aliceChannelState, aliceSigner, nil, aliceChannelState,
) )
if err != nil { if err != nil {
return nil, nil, nil, nil, err return nil, nil, nil, nil, err
} }
channelBob, err := lnwallet.NewLightningChannel( channelBob, err := lnwallet.NewLightningChannel(
bobSigner, notifier, nil, bobChannelState, bobSigner, nil, bobChannelState,
) )
if err != nil { if err != nil {
return nil, nil, nil, nil, err return nil, nil, nil, nil, err