1
0
mirror of https://github.com/PurpleI2P/i2pd.git synced 2025-01-22 16:34:13 +00:00

verify signature for PeerTest msg 4

This commit is contained in:
orignal 2022-06-21 18:54:13 -04:00
parent dda25d431c
commit 694b936f30

View File

@ -1473,13 +1473,13 @@ namespace transport
case 2: // Charlie from Bob case 2: // Charlie from Bob
{ {
// sign with Charlie's key // sign with Charlie's key
uint8_t asz = buf[44]; uint8_t asz = buf[offset + 9];
std::vector<uint8_t> newSignedData (asz + 10 + i2p::context.GetIdentity ()->GetSignatureLen ()); std::vector<uint8_t> newSignedData (asz + 10 + i2p::context.GetIdentity ()->GetSignatureLen ());
SignedData s; SignedData s;
s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
s.Insert (buf + 3, 32); // ahash s.Insert (buf + 3, 32); // ahash
s.Insert (buf + 35, asz + 10); // ver, nonce, ts, asz, Alice's endpoint s.Insert (buf + offset, asz + 10); // ver, nonce, ts, asz, Alice's endpoint
s.Sign (i2p::context.GetPrivateKeys (), newSignedData.data () + 10 + asz); s.Sign (i2p::context.GetPrivateKeys (), newSignedData.data () + 10 + asz);
// send response (msg 3) back and msg 5 if accepted // send response (msg 3) back and msg 5 if accepted
SSU2PeerTestCode code = eSSU2PeerTestCodeAccept; SSU2PeerTestCode code = eSSU2PeerTestCodeAccept;
@ -1487,19 +1487,19 @@ namespace transport
if (r) if (r)
{ {
size_t signatureLen = r->GetIdentity ()->GetSignatureLen (); size_t signatureLen = r->GetIdentity ()->GetSignatureLen ();
if (len >= 35 + asz + 10 + signatureLen) if (len >= offset + asz + 10 + signatureLen)
{ {
s.Reset (); s.Reset ();
s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
s.Insert (buf + 35, asz + 10); // signed data s.Insert (buf + offset, asz + 10); // signed data
if (s.Verify (r->GetIdentity (), buf + 35 + asz + 10)) if (s.Verify (r->GetIdentity (), buf + offset + asz + 10))
{ {
if (!m_Server.FindSession (r->GetIdentity ()->GetIdentHash ())) if (!m_Server.FindSession (r->GetIdentity ()->GetIdentHash ()))
{ {
boost::asio::ip::udp::endpoint ep; boost::asio::ip::udp::endpoint ep;
std::shared_ptr<const i2p::data::RouterInfo::Address> addr; std::shared_ptr<const i2p::data::RouterInfo::Address> addr;
if (ExtractEndpoint (buf + 44, len - 44, ep)) if (ExtractEndpoint (buf + offset + 9, len - offset - 9, ep))
addr = r->GetSSU2Address (ep.address ().is_v4 ()); addr = r->GetSSU2Address (ep.address ().is_v4 ());
if (addr) if (addr)
{ {
@ -1569,19 +1569,41 @@ namespace transport
auto it = m_PeerTests.find (nonce); auto it = m_PeerTests.find (nonce);
if (it != m_PeerTests.end ()) if (it != m_PeerTests.end ())
{ {
auto r = i2p::data::netdb.FindRouter (buf + 3); // find Charlie if (buf[1] == eSSU2PeerTestCodeAccept)
if (r && it->second.first)
{ {
it->second.first->SetRemoteIdentity (r->GetIdentity ()); auto r = i2p::data::netdb.FindRouter (buf + 3); // find Charlie
auto addr = r->GetSSU2Address (m_Address->IsV4 ()); if (r && it->second.first)
if (addr) {
it->second.first->m_Address = addr; uint8_t asz = buf[offset + 9];
if (it->second.first->m_State == eSSU2SessionStatePeerTestReceived) SignedData s;
{ s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue
// msg 5 already received. send msg 6 s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
it->second.first->m_State = eSSU2SessionStatePeerTest; s.Insert (i2p::context.GetIdentity ()->GetIdentHash (), 32); // ahash
it->second.first->SendPeerTest (6, buf + offset, len - offset, addr->i); s.Insert (buf + offset, asz + 10); // ver, nonce, ts, asz, Alice's endpoint
if (s.Verify (r->GetIdentity (), buf + offset + asz + 10))
{
it->second.first->SetRemoteIdentity (r->GetIdentity ());
auto addr = r->GetSSU2Address (m_Address->IsV4 ());
if (addr)
it->second.first->m_Address = addr;
if (it->second.first->m_State == eSSU2SessionStatePeerTestReceived)
{
// msg 5 already received. send msg 6
it->second.first->m_State = eSSU2SessionStatePeerTest;
it->second.first->SendPeerTest (6, buf + offset, len - offset, addr->i);
}
}
else
{
LogPrint (eLogInfo, "SSU2: Peer test 4 signature verification failed");
it->second.first->Terminate ();
}
} }
}
else
{
LogPrint (eLogInfo, "SSU2: Peer test 4 error code ", (int)buf[1]);
it->second.first->Terminate ();
} }
m_PeerTests.erase (it); m_PeerTests.erase (it);
} }