Browse Source

Don't assume roots validated the identity, just in case they did not.

pull/4/head
Adam Ierymenko 5 years ago committed by Grant Limberg
parent
commit
9cfb807fcb
No known key found for this signature in database
GPG Key ID: 2BA62CCABBB4095A
  1. 5
      node/IncomingPacket.cpp

5
node/IncomingPacket.cpp

@ -511,7 +511,10 @@ bool IncomingPacket::_doOK(const RuntimeEnvironment *RR,void *tPtr,const SharedP
case Packet::VERB_WHOIS:
if (RR->topology->isUpstream(peer->identity())) {
const Identity id(*this,ZT_PROTO_VERB_WHOIS__OK__IDX_IDENTITY);
RR->sw->doAnythingWaitingForPeer(tPtr,RR->topology->addPeer(tPtr,SharedPtr<Peer>(new Peer(RR,RR->identity,id))));
// Good idea to locally validate here even if roots are doing so. In a truly distributed
// system there should not be single points of failure for global trust assertions.
if (id.locallyValidate())
RR->sw->doAnythingWaitingForPeer(tPtr,RR->topology->addPeer(tPtr,SharedPtr<Peer>(new Peer(RR,RR->identity,id))));
}
break;

Loading…
Cancel
Save