discovery: return an error if ChannelUpdate has unknown flags
In this commit, we fix an existing bug that could result in a panic if we received a ChannelUpdate message with an unknown set of flags. If the flag wasn’t set to zero or one, then the pubKey parameter would be still nil when we attempted to validate it, causing an error to occur. We remedy this by instead returning an error if the flags are unknown. In a future commit, we will properly handle the set of flags that indicates the channel should be disabled.
This commit is contained in:
parent
249e578130
commit
8c181b6f4e
@ -885,6 +885,12 @@ func (d *AuthenticatedGossiper) processNetworkAnnouncement(nMsg *networkMsg) []l
|
|||||||
pubKey = chanInfo.NodeKey1
|
pubKey = chanInfo.NodeKey1
|
||||||
case 1:
|
case 1:
|
||||||
pubKey = chanInfo.NodeKey2
|
pubKey = chanInfo.NodeKey2
|
||||||
|
default:
|
||||||
|
rErr := errors.Errorf("unknown flags=%v for "+
|
||||||
|
"short_chan_id=%v", msg.Flags, shortChanID)
|
||||||
|
log.Error(rErr)
|
||||||
|
nMsg.err <- rErr
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Validate the channel announcement with the expected public
|
// Validate the channel announcement with the expected public
|
||||||
|
Loading…
Reference in New Issue
Block a user