mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 08:14:15 +00:00
use generic receive buffer for phase 4
This commit is contained in:
parent
4778c8bdfb
commit
9eb5982ea3
@ -308,10 +308,10 @@ namespace transport
|
|||||||
{
|
{
|
||||||
LogPrint ("Phase 3 sent: ", bytes_transferred);
|
LogPrint ("Phase 3 sent: ", bytes_transferred);
|
||||||
// wait for phase4
|
// wait for phase4
|
||||||
m_Establisher->phase4Len = m_RemoteIdentity.GetSignatureLen ();
|
auto signatureLen = m_RemoteIdentity.GetSignatureLen ();
|
||||||
size_t paddingSize = m_Establisher->phase4Len & 0x0F; // %16
|
size_t paddingSize = signatureLen & 0x0F; // %16
|
||||||
if (paddingSize > 0) m_Establisher->phase4Len += (16 - paddingSize);
|
if (paddingSize > 0) signatureLen += (16 - paddingSize);
|
||||||
boost::asio::async_read (m_Socket, boost::asio::buffer(m_Establisher->phase4, m_Establisher->phase4Len), boost::asio::transfer_all (),
|
boost::asio::async_read (m_Socket, boost::asio::buffer(m_ReceiveBuffer, signatureLen), boost::asio::transfer_all (),
|
||||||
boost::bind(&NTCPSession::HandlePhase4Received, this,
|
boost::bind(&NTCPSession::HandlePhase4Received, this,
|
||||||
boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred, tsA));
|
boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred, tsA));
|
||||||
}
|
}
|
||||||
@ -357,19 +357,13 @@ namespace transport
|
|||||||
s.Insert (m_Establisher->phase3.timestamp); // tsA
|
s.Insert (m_Establisher->phase3.timestamp); // tsA
|
||||||
s.Insert (tsB); // tsB
|
s.Insert (tsB); // tsB
|
||||||
auto keys = i2p::context.GetPrivateKeys ();
|
auto keys = i2p::context.GetPrivateKeys ();
|
||||||
m_Establisher->phase4Len = keys.GetPublic ().GetSignatureLen ();
|
auto signatureLen = keys.GetPublic ().GetSignatureLen ();
|
||||||
if (m_Establisher->phase4Len > 64)
|
s.Sign (keys, m_ReceiveBuffer);
|
||||||
{
|
size_t paddingSize = signatureLen & 0x0F; // %16
|
||||||
LogPrint (eLogError, "Signature length ", m_Establisher->phase4Len, " exceeds 64");
|
if (paddingSize > 0) signatureLen += (16 - paddingSize);
|
||||||
Terminate ();
|
m_Encryption.Encrypt (m_ReceiveBuffer, signatureLen, m_ReceiveBuffer);
|
||||||
}
|
|
||||||
s.Sign (keys, m_Establisher->phase4);
|
|
||||||
size_t paddingSize = m_Establisher->phase4Len & 0x0F; // %16
|
|
||||||
if (paddingSize > 0) m_Establisher->phase4Len += (16 - paddingSize);
|
|
||||||
|
|
||||||
m_Encryption.Encrypt (m_Establisher->phase4, m_Establisher->phase4Len, m_Establisher->phase4);
|
boost::asio::async_write (m_Socket, boost::asio::buffer (m_ReceiveBuffer, signatureLen), boost::asio::transfer_all (),
|
||||||
|
|
||||||
boost::asio::async_write (m_Socket, boost::asio::buffer (m_Establisher->phase4, m_Establisher->phase4Len), boost::asio::transfer_all (),
|
|
||||||
boost::bind(&NTCPSession::HandlePhase4Sent, this, boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred));
|
boost::bind(&NTCPSession::HandlePhase4Sent, this, boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -406,7 +400,7 @@ namespace transport
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
LogPrint ("Phase 4 received: ", bytes_transferred);
|
LogPrint ("Phase 4 received: ", bytes_transferred);
|
||||||
m_Decryption.Decrypt(m_Establisher->phase4, m_Establisher->phase4Len, m_Establisher->phase4);
|
m_Decryption.Decrypt(m_ReceiveBuffer, bytes_transferred, m_ReceiveBuffer);
|
||||||
|
|
||||||
// verify signature
|
// verify signature
|
||||||
SignedData s;
|
SignedData s;
|
||||||
@ -416,7 +410,7 @@ namespace transport
|
|||||||
s.Insert (tsA); // tsA
|
s.Insert (tsA); // tsA
|
||||||
s.Insert (m_Establisher->phase2.encrypted.timestamp); // tsB
|
s.Insert (m_Establisher->phase2.encrypted.timestamp); // tsB
|
||||||
|
|
||||||
if (!s.Verify (m_RemoteIdentity, m_Establisher->phase4))
|
if (!s.Verify (m_RemoteIdentity, m_ReceiveBuffer))
|
||||||
{
|
{
|
||||||
LogPrint ("signature verification failed");
|
LogPrint ("signature verification failed");
|
||||||
Terminate ();
|
Terminate ();
|
||||||
|
@ -122,11 +122,10 @@ namespace transport
|
|||||||
NTCPPhase1 phase1;
|
NTCPPhase1 phase1;
|
||||||
NTCPPhase2 phase2;
|
NTCPPhase2 phase2;
|
||||||
NTCPPhase3 phase3;
|
NTCPPhase3 phase3;
|
||||||
i2p::crypto::AESAlignedBuffer<64> phase4; // 64 bytes max signature len
|
|
||||||
size_t phase4Len;
|
|
||||||
} * m_Establisher;
|
} * m_Establisher;
|
||||||
|
|
||||||
uint8_t m_ReceiveBuffer[NTCP_BUFFER_SIZE + 16], m_TimeSyncBuffer[16];
|
i2p::crypto::AESAlignedBuffer<NTCP_BUFFER_SIZE + 16> m_ReceiveBuffer;
|
||||||
|
i2p::crypto::AESAlignedBuffer<16> m_TimeSyncBuffer;
|
||||||
int m_ReceiveBufferOffset;
|
int m_ReceiveBufferOffset;
|
||||||
|
|
||||||
i2p::I2NPMessage * m_NextMessage;
|
i2p::I2NPMessage * m_NextMessage;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user