Merge pull request #2030 from halseth/authsig-len

Validate own node announcement, signature length
This commit is contained in:
Olaoluwa Osuntokun 2018-12-05 21:08:46 -08:00 committed by GitHub
commit 1d1e9f2c44
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 19 additions and 15 deletions

@ -2839,6 +2839,12 @@ func putLightningNode(nodeBucket *bbolt.Bucket, aliasBucket *bbolt.Bucket,
} }
} }
sigLen := len(node.AuthSigBytes)
if sigLen > 80 {
return fmt.Errorf("max sig len allowed is 80, had %v",
sigLen)
}
err = wire.WriteVarBytes(&b, 0, node.AuthSigBytes) err = wire.WriteVarBytes(&b, 0, node.AuthSigBytes)
if err != nil { if err != nil {
return err return err

@ -1577,22 +1577,20 @@ func (d *AuthenticatedGossiper) processNetworkAnnouncement(
case *lnwire.NodeAnnouncement: case *lnwire.NodeAnnouncement:
timestamp := time.Unix(int64(msg.Timestamp), 0) timestamp := time.Unix(int64(msg.Timestamp), 0)
if nMsg.isRemote { // We'll quickly ask the router if it already has a
// We'll quickly ask the router if it already has a // newer update for this node so we can skip validating
// newer update for this node so we can skip validating // signatures if not required.
// signatures if not required. if d.cfg.Router.IsStaleNode(msg.NodeID, timestamp) {
if d.cfg.Router.IsStaleNode(msg.NodeID, timestamp) { nMsg.err <- nil
nMsg.err <- nil return nil
return nil }
}
if err := routing.ValidateNodeAnn(msg); err != nil { if err := routing.ValidateNodeAnn(msg); err != nil {
err := fmt.Errorf("unable to validate "+ err := fmt.Errorf("unable to validate "+
"node announcement: %v", err) "node announcement: %v", err)
log.Error(err) log.Error(err)
nMsg.err <- err nMsg.err <- err
return nil return nil
}
} }
features := lnwire.NewFeatureVector( features := lnwire.NewFeatureVector(