mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-03-10 19:38:28 +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;
|
if (!asz) return false;
|
||||||
payload[17] = asz;
|
payload[17] = asz;
|
||||||
packet->payloadSize = asz + 18;
|
packet->payloadSize = asz + 18;
|
||||||
SignedData s;
|
SignedData<128> s;
|
||||||
s.Insert ((const uint8_t *)"RelayRequestData", 16); // prologue
|
s.Insert ((const uint8_t *)"RelayRequestData", 16); // prologue
|
||||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||||
s.Insert (session->GetRemoteIdentity ()->GetIdentHash (), 32); // chash
|
s.Insert (session->GetRemoteIdentity ()->GetIdentHash (), 32); // chash
|
||||||
|
@ -2021,7 +2021,7 @@ namespace transport
|
||||||
auto r = i2p::data::netdb.FindRouter (buf + 1); // Alice
|
auto r = i2p::data::netdb.FindRouter (buf + 1); // Alice
|
||||||
if (r)
|
if (r)
|
||||||
{
|
{
|
||||||
SignedData s;
|
SignedData<128> s;
|
||||||
s.Insert ((const uint8_t *)"RelayRequestData", 16); // prologue
|
s.Insert ((const uint8_t *)"RelayRequestData", 16); // prologue
|
||||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||||
s.Insert (i2p::context.GetIdentHash (), 32); // chash
|
s.Insert (i2p::context.GetIdentHash (), 32); // chash
|
||||||
|
@ -2174,7 +2174,7 @@ namespace transport
|
||||||
relaySession->Done ();
|
relaySession->Done ();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
SignedData s;
|
SignedData<128> s;
|
||||||
s.Insert ((const uint8_t *)"RelayAgreementOK", 16); // prologue
|
s.Insert ((const uint8_t *)"RelayAgreementOK", 16); // prologue
|
||||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
||||||
s.Insert (buf + 2, 10 + csz); // nonce, timestamp, ver, csz and Charlie's endpoint
|
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];
|
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 ());
|
||||||
memcpy (newSignedData.data (), buf + offset, asz + 10);
|
memcpy (newSignedData.data (), buf + offset, asz + 10);
|
||||||
SignedData s;
|
SignedData<128> 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
|
||||||
|
@ -2391,7 +2391,7 @@ namespace transport
|
||||||
if (r)
|
if (r)
|
||||||
{
|
{
|
||||||
uint8_t asz = buf[offset + 9];
|
uint8_t asz = buf[offset + 9];
|
||||||
SignedData s;
|
SignedData<128> 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 (i2p::context.GetIdentity ()->GetIdentHash (), 32); // ahash
|
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);
|
LogPrint (eLogError, "SSU2: Buffer for RelayResponse signature is too small ", len);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
SignedData s;
|
SignedData<128> s;
|
||||||
s.Insert ((const uint8_t *)"RelayAgreementOK", 16); // prologue
|
s.Insert ((const uint8_t *)"RelayAgreementOK", 16); // prologue
|
||||||
if (code == eSSU2RelayResponseCodeAccept || code >= 64) // Charlie
|
if (code == eSSU2RelayResponseCodeAccept || code >= 64) // Charlie
|
||||||
s.Insert (GetRemoteIdentity ()->GetIdentHash (), 32); // bhash
|
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));
|
size_t asz = CreateEndpoint (signedData + 10, 86, boost::asio::ip::udp::endpoint (localAddress->host, localAddress->port));
|
||||||
signedData[9] = asz;
|
signedData[9] = asz;
|
||||||
// signature
|
// signature
|
||||||
SignedData s;
|
SignedData<128> 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 (signedData, 10 + asz); // ver, nonce, ts, asz, Alice's endpoint
|
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
|
* This file is part of Purple i2pd project and licensed under BSD3
|
||||||
*
|
*
|
||||||
|
@ -10,7 +10,7 @@
|
||||||
#define TRANSPORT_SESSION_H__
|
#define TRANSPORT_SESSION_H__
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include <iostream>
|
#include <string.h>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
|
@ -28,45 +28,51 @@ namespace transport
|
||||||
const size_t IPV6_HEADER_SIZE = 40;
|
const size_t IPV6_HEADER_SIZE = 40;
|
||||||
const size_t UDP_HEADER_SIZE = 8;
|
const size_t UDP_HEADER_SIZE = 8;
|
||||||
|
|
||||||
|
template<size_t sz>
|
||||||
class SignedData
|
class SignedData
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
SignedData () {}
|
SignedData (): m_Size(0) {}
|
||||||
SignedData (const SignedData& other)
|
SignedData (const SignedData& other)
|
||||||
{
|
{
|
||||||
m_Stream << other.m_Stream.rdbuf ();
|
m_Size = other.Size;
|
||||||
|
memcpy (m_Buf, other.m_Buf, m_Size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Reset ()
|
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>
|
template<typename T>
|
||||||
void Insert (T 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
|
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
|
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:
|
private:
|
||||||
|
|
||||||
std::stringstream m_Stream;
|
uint8_t m_Buf[sz];
|
||||||
|
size_t m_Size;
|
||||||
};
|
};
|
||||||
|
|
||||||
const int64_t TRANSPORT_SESSION_SLOWNESS_THRESHOLD = 500; // in milliseconds
|
const int64_t TRANSPORT_SESSION_SLOWNESS_THRESHOLD = 500; // in milliseconds
|
||||||
|
|
Loading…
Add table
Reference in a new issue