contractcourt: make empty htlcSets for closed channels

This prevents a panic where an insert is attempted on a nil map via
updateActiveHTLCs. This panic would occur if the channel arbitrator
was in a buggy state, possibly introduced by power loss or via
SIGKILL.
This commit is contained in:
eugene 2022-05-27 16:18:02 -04:00
parent 08e4e66574
commit 160d63b88e
No known key found for this signature in database
GPG Key ID: 118759E83439A9B1

View File

@ -601,11 +601,13 @@ func (c *ChainArbitrator) Start() error {
return c.ResolveContract(chanPoint)
}
// We can also leave off the set of HTLC's here as since the
// channel is already in the process of being full resolved, no
// new HTLC's will be added.
// We create an empty map of HTLC's here since it's possible
// that the channel is in StateDefault and updateActiveHTLCs is
// called. We want to avoid writing to an empty map. Since the
// channel is already in the process of being resolved, no new
// HTLCs will be added.
c.activeChannels[chanPoint] = NewChannelArbitrator(
arbCfg, nil, chanLog,
arbCfg, make(map[HtlcSetKey]htlcSet), chanLog,
)
}