mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-10-23 20:19:03 +01:00
use plain buffer instead stream for SignedData
This commit is contained in:
parent
7791b3952e
commit
9ba016259d
2 changed files with 24 additions and 18 deletions
|
@ -189,7 +189,7 @@ namespace transport
|
|||
if (!asz) return false;
|
||||
payload[17] = asz;
|
||||
packet->payloadSize = asz + 18;
|
||||
SignedData s;
|
||||
SignedData<128> s;
|
||||
s.Insert ((const uint8_t *)"RelayRequestData", 16); // prologue
|
||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||
s.Insert (session->GetRemoteIdentity ()->GetIdentHash (), 32); // chash
|
||||
|
@ -2021,7 +2021,7 @@ namespace transport
|
|||
auto r = i2p::data::netdb.FindRouter (buf + 1); // Alice
|
||||
if (r)
|
||||
{
|
||||
SignedData s;
|
||||
SignedData<128> s;
|
||||
s.Insert ((const uint8_t *)"RelayRequestData", 16); // prologue
|
||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||
s.Insert (i2p::context.GetIdentHash (), 32); // chash
|
||||
|
@ -2174,7 +2174,7 @@ namespace transport
|
|||
relaySession->Done ();
|
||||
return;
|
||||
}
|
||||
SignedData s;
|
||||
SignedData<128> s;
|
||||
s.Insert ((const uint8_t *)"RelayAgreementOK", 16); // prologue
|
||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||
s.Insert (buf + 2, 10 + csz); // nonce, timestamp, ver, csz and Charlie's endpoint
|
||||
|
@ -2280,7 +2280,7 @@ namespace transport
|
|||
uint8_t asz = buf[offset + 9];
|
||||
std::vector<uint8_t> newSignedData (asz + 10 + i2p::context.GetIdentity ()->GetSignatureLen ());
|
||||
memcpy (newSignedData.data (), buf + offset, asz + 10);
|
||||
SignedData s;
|
||||
SignedData<128> s;
|
||||
s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue
|
||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||
s.Insert (buf + 3, 32); // ahash
|
||||
|
@ -2391,7 +2391,7 @@ namespace transport
|
|||
if (r)
|
||||
{
|
||||
uint8_t asz = buf[offset + 9];
|
||||
SignedData s;
|
||||
SignedData<128> s;
|
||||
s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue
|
||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||
s.Insert (i2p::context.GetIdentity ()->GetIdentHash (), 32); // ahash
|
||||
|
@ -2879,7 +2879,7 @@ namespace transport
|
|||
LogPrint (eLogError, "SSU2: Buffer for RelayResponse signature is too small ", len);
|
||||
return 0;
|
||||
}
|
||||
SignedData s;
|
||||
SignedData<128> s;
|
||||
s.Insert ((const uint8_t *)"RelayAgreementOK", 16); // prologue
|
||||
if (code == eSSU2RelayResponseCodeAccept || code >= 64) // Charlie
|
||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||
|
@ -2941,7 +2941,7 @@ namespace transport
|
|||
size_t asz = CreateEndpoint (signedData + 10, 86, boost::asio::ip::udp::endpoint (localAddress->host, localAddress->port));
|
||||
signedData[9] = asz;
|
||||
// signature
|
||||
SignedData s;
|
||||
SignedData<128> s;
|
||||
s.Insert ((const uint8_t *)"PeerTestValidate", 16); // prologue
|
||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||
s.Insert (signedData, 10 + asz); // ver, nonce, ts, asz, Alice's endpoint
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (c) 2013-2024, The PurpleI2P Project
|
||||
* Copyright (c) 2013-2025, The PurpleI2P Project
|
||||
*
|
||||
* This file is part of Purple i2pd project and licensed under BSD3
|
||||
*
|
||||
|
@ -10,7 +10,7 @@
|
|||
#define TRANSPORT_SESSION_H__
|
||||
|
||||
#include <inttypes.h>
|
||||
#include <iostream>
|
||||
#include <string.h>
|
||||
#include <memory>
|
||||
#include <vector>
|
||||
#include <mutex>
|
||||
|
@ -28,45 +28,51 @@ namespace transport
|
|||
const size_t IPV6_HEADER_SIZE = 40;
|
||||
const size_t UDP_HEADER_SIZE = 8;
|
||||
|
||||
template<size_t sz>
|
||||
class SignedData
|
||||
{
|
||||
public:
|
||||
|
||||
SignedData () {}
|
||||
SignedData (): m_Size(0) {}
|
||||
SignedData (const SignedData& other)
|
||||
{
|
||||
m_Stream << other.m_Stream.rdbuf ();
|
||||
m_Size = other.Size;
|
||||
memcpy (m_Buf, other.m_Buf, m_Size);
|
||||
}
|
||||
|
||||
void Reset ()
|
||||
{
|
||||
m_Stream.str("");
|
||||
m_Size = 0;
|
||||
}
|
||||
|
||||
void Insert (const uint8_t * buf, size_t len)
|
||||
size_t Insert (const uint8_t * buf, size_t len)
|
||||
{
|
||||
m_Stream.write ((char *)buf, len);
|
||||
if (m_Size + len > sz) len = sz - m_Size;
|
||||
memcpy (m_Buf + m_Size, buf, len);
|
||||
m_Size += len;
|
||||
return len;
|
||||
}
|
||||
|
||||
template<typename T>
|
||||
void Insert (T t)
|
||||
{
|
||||
m_Stream.write ((char *)&t, sizeof (T));
|
||||
Insert ((const uint8_t *)&t, sizeof (T));
|
||||
}
|
||||
|
||||
bool Verify (std::shared_ptr<const i2p::data::IdentityEx> ident, const uint8_t * signature) const
|
||||
{
|
||||
return ident->Verify ((const uint8_t *)m_Stream.str ().c_str (), m_Stream.str ().size (), signature);
|
||||
return ident->Verify (m_Buf, m_Size, signature);
|
||||
}
|
||||
|
||||
void Sign (const i2p::data::PrivateKeys& keys, uint8_t * signature) const
|
||||
{
|
||||
keys.Sign ((const uint8_t *)m_Stream.str ().c_str (), m_Stream.str ().size (), signature);
|
||||
keys.Sign (m_Buf, m_Size, signature);
|
||||
}
|
||||
|
||||
private:
|
||||
|
||||
std::stringstream m_Stream;
|
||||
uint8_t m_Buf[sz];
|
||||
size_t m_Size;
|
||||
};
|
||||
|
||||
const int64_t TRANSPORT_SESSION_SLOWNESS_THRESHOLD = 500; // in milliseconds
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue