fundingmanager: fixes range-goroutine scoping bug
This commit fixes an issue in funding manager startup, where a goroutine reads from a range value. The method in question could cause a channel to be announced at the wrong time. This may have been a cause for certain channels having phantom HTLCs before they had even received the funding locked message from the remote peer. This is fixed simply by using the locally scoped variable passed in as an argument to the goroutine.
This commit is contained in:
parent
16c304a4c1
commit
5c43e0ad02
@ -640,7 +640,7 @@ func (f *fundingManager) Start() error {
|
|||||||
go func(dbChan *channeldb.OpenChannel) {
|
go func(dbChan *channeldb.OpenChannel) {
|
||||||
defer f.wg.Done()
|
defer f.wg.Done()
|
||||||
|
|
||||||
err = f.annAfterSixConfs(channel, shortChanID)
|
err = f.annAfterSixConfs(dbChan, shortChanID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fndgLog.Errorf("error sending channel "+
|
fndgLog.Errorf("error sending channel "+
|
||||||
"announcement: %v", err)
|
"announcement: %v", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user