contractcourt/chain_arbitrator: markChanClosed->notifyChanClosed
We no longer have to mark the channel as fully closed in the database, as it is done directly in the chainWatcher. Instead, we stop the watcher and delete it from the set of active watchers.
This commit is contained in:
parent
0f077fcb54
commit
921f02fe22
@ -341,9 +341,22 @@ func (c *ChainArbitrator) Start() error {
|
|||||||
pCache: c.cfg.PreimageDB,
|
pCache: c.cfg.PreimageDB,
|
||||||
signer: c.cfg.Signer,
|
signer: c.cfg.Signer,
|
||||||
isOurAddr: c.cfg.IsOurAddress,
|
isOurAddr: c.cfg.IsOurAddress,
|
||||||
markChanClosed: func() error {
|
notifyChanClosed: func() error {
|
||||||
// TODO(roasbeef): also need to pass in log?
|
c.Lock()
|
||||||
return c.resolveContract(chanPoint, nil)
|
delete(c.activeChannels, chanPoint)
|
||||||
|
|
||||||
|
chainWatcher, ok := c.activeWatchers[chanPoint]
|
||||||
|
if ok {
|
||||||
|
// Since the chainWatcher is
|
||||||
|
// calling notifyChanClosed, we
|
||||||
|
// must stop it in a goroutine
|
||||||
|
// to not deadlock.
|
||||||
|
go chainWatcher.Stop()
|
||||||
|
}
|
||||||
|
delete(c.activeWatchers, chanPoint)
|
||||||
|
c.Unlock()
|
||||||
|
|
||||||
|
return nil
|
||||||
},
|
},
|
||||||
contractBreach: func(retInfo *lnwallet.BreachRetribution) error {
|
contractBreach: func(retInfo *lnwallet.BreachRetribution) error {
|
||||||
return c.cfg.ContractBreach(chanPoint, retInfo)
|
return c.cfg.ContractBreach(chanPoint, retInfo)
|
||||||
@ -677,8 +690,21 @@ func (c *ChainArbitrator) WatchNewChannel(newChan *channeldb.OpenChannel) error
|
|||||||
pCache: c.cfg.PreimageDB,
|
pCache: c.cfg.PreimageDB,
|
||||||
signer: c.cfg.Signer,
|
signer: c.cfg.Signer,
|
||||||
isOurAddr: c.cfg.IsOurAddress,
|
isOurAddr: c.cfg.IsOurAddress,
|
||||||
markChanClosed: func() error {
|
notifyChanClosed: func() error {
|
||||||
return c.resolveContract(chanPoint, nil)
|
c.Lock()
|
||||||
|
delete(c.activeChannels, chanPoint)
|
||||||
|
|
||||||
|
chainWatcher, ok := c.activeWatchers[chanPoint]
|
||||||
|
if ok {
|
||||||
|
// Since the chainWatcher is calling
|
||||||
|
// notifyChanClosed, we must stop it in
|
||||||
|
// a goroutine to not deadlock.
|
||||||
|
go chainWatcher.Stop()
|
||||||
|
}
|
||||||
|
delete(c.activeWatchers, chanPoint)
|
||||||
|
c.Unlock()
|
||||||
|
|
||||||
|
return nil
|
||||||
},
|
},
|
||||||
contractBreach: func(retInfo *lnwallet.BreachRetribution) error {
|
contractBreach: func(retInfo *lnwallet.BreachRetribution) error {
|
||||||
return c.cfg.ContractBreach(chanPoint, retInfo)
|
return c.cfg.ContractBreach(chanPoint, retInfo)
|
||||||
|
Loading…
Reference in New Issue
Block a user