discovery: check proof for nilness before creating chanAnn
This commit makes sure we are not attempting to create a channel announcement with a nil ChannelAuthProof, as that could cause a crash at startup whe the gossiper would attempt to reprocess an edge coming from the fundingmanager. It also makes sure we check the correct error returned from processRejectedEdge.
This commit is contained in:
parent
6b0f984e31
commit
2ddd139084
@ -1118,7 +1118,12 @@ func (d *AuthenticatedGossiper) processRejectedEdge(chanAnnMsg *lnwire.ChannelAn
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise, this means that the edge is within the graph, but it
|
// Otherwise, this means that the edge is within the graph, but it
|
||||||
// doesn't yet have a proper proof attached.
|
// doesn't yet have a proper proof attached. If we did not receive
|
||||||
|
// the proof such that we now can add it, there's nothing more we
|
||||||
|
// can do.
|
||||||
|
if proof == nil {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
// We'll then create then validate the new fully assembled
|
// We'll then create then validate the new fully assembled
|
||||||
// announcement.
|
// announcement.
|
||||||
@ -1329,7 +1334,7 @@ func (d *AuthenticatedGossiper) processNetworkAnnouncement(nMsg *networkMsg) []n
|
|||||||
// Attempt to process the rejected message to
|
// Attempt to process the rejected message to
|
||||||
// see if we get any new announcements.
|
// see if we get any new announcements.
|
||||||
anns, rErr := d.processRejectedEdge(msg, proof)
|
anns, rErr := d.processRejectedEdge(msg, proof)
|
||||||
if err != nil {
|
if rErr != nil {
|
||||||
nMsg.err <- rErr
|
nMsg.err <- rErr
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user