mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-03-07 06:09:42 +00:00
handle session handshakes in separate thread
This commit is contained in:
@@ -491,7 +491,6 @@ namespace transport
|
|||||||
|
|
||||||
void NTCP2Session::HandleSessionRequestReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred)
|
void NTCP2Session::HandleSessionRequestReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred)
|
||||||
{
|
{
|
||||||
(void) bytes_transferred;
|
|
||||||
if (ecode)
|
if (ecode)
|
||||||
{
|
{
|
||||||
LogPrint (eLogWarning, "NTCP2: SessionRequest read error: ", ecode.message ());
|
LogPrint (eLogWarning, "NTCP2: SessionRequest read error: ", ecode.message ());
|
||||||
@@ -499,36 +498,45 @@ namespace transport
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LogPrint (eLogDebug, "NTCP2: SessionRequest received ", bytes_transferred);
|
boost::asio::post (m_Server.GetEstablisherService (),
|
||||||
uint16_t paddingLen = 0;
|
[s = shared_from_this (), bytes_transferred] ()
|
||||||
bool clockSkew = false;
|
{
|
||||||
if (m_Establisher->ProcessSessionRequestMessage (paddingLen, clockSkew))
|
s->ProcessSessionRequest (bytes_transferred);;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void NTCP2Session::ProcessSessionRequest (size_t len)
|
||||||
|
{
|
||||||
|
LogPrint (eLogDebug, "NTCP2: SessionRequest received ", len);
|
||||||
|
uint16_t paddingLen = 0;
|
||||||
|
bool clockSkew = false;
|
||||||
|
if (m_Establisher->ProcessSessionRequestMessage (paddingLen, clockSkew))
|
||||||
|
{
|
||||||
|
if (clockSkew)
|
||||||
{
|
{
|
||||||
if (clockSkew)
|
// we don't care about padding, send SessionCreated and close session
|
||||||
|
SendSessionCreated ();
|
||||||
|
boost::asio::post (m_Server.GetService (), std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
||||||
|
}
|
||||||
|
else if (paddingLen > 0)
|
||||||
|
{
|
||||||
|
if (paddingLen <= NTCP2_SESSION_REQUEST_MAX_SIZE - 64) // session request is 287 bytes max
|
||||||
{
|
{
|
||||||
// we don't care about padding, send SessionCreated and close session
|
boost::asio::async_read (m_Socket, boost::asio::buffer(m_Establisher->m_SessionRequestBuffer + 64, paddingLen), boost::asio::transfer_all (),
|
||||||
SendSessionCreated ();
|
std::bind(&NTCP2Session::HandleSessionRequestPaddingReceived, shared_from_this (), std::placeholders::_1, std::placeholders::_2));
|
||||||
boost::asio::post (m_Server.GetService (), std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
|
||||||
}
|
|
||||||
else if (paddingLen > 0)
|
|
||||||
{
|
|
||||||
if (paddingLen <= NTCP2_SESSION_REQUEST_MAX_SIZE - 64) // session request is 287 bytes max
|
|
||||||
{
|
|
||||||
boost::asio::async_read (m_Socket, boost::asio::buffer(m_Establisher->m_SessionRequestBuffer + 64, paddingLen), boost::asio::transfer_all (),
|
|
||||||
std::bind(&NTCP2Session::HandleSessionRequestPaddingReceived, shared_from_this (), std::placeholders::_1, std::placeholders::_2));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
LogPrint (eLogWarning, "NTCP2: SessionRequest padding length ", (int)paddingLen, " is too long");
|
|
||||||
Terminate ();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
SendSessionCreated ();
|
{
|
||||||
|
LogPrint (eLogWarning, "NTCP2: SessionRequest padding length ", (int)paddingLen, " is too long");
|
||||||
|
boost::asio::post (m_Server.GetService (), std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
Terminate ();
|
SendSessionCreated ();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
boost::asio::post (m_Server.GetService (), std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void NTCP2Session::HandleSessionRequestPaddingReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred)
|
void NTCP2Session::HandleSessionRequestPaddingReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred)
|
||||||
@@ -539,7 +547,13 @@ namespace transport
|
|||||||
Terminate ();
|
Terminate ();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
SendSessionCreated ();
|
{
|
||||||
|
boost::asio::post (m_Server.GetEstablisherService (),
|
||||||
|
[s = shared_from_this ()] ()
|
||||||
|
{
|
||||||
|
s->SendSessionCreated ();
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void NTCP2Session::SendSessionCreated ()
|
void NTCP2Session::SendSessionCreated ()
|
||||||
@@ -561,32 +575,41 @@ namespace transport
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_HandshakeInterval = i2p::util::GetMillisecondsSinceEpoch () - m_HandshakeInterval;
|
m_HandshakeInterval = i2p::util::GetMillisecondsSinceEpoch () - m_HandshakeInterval;
|
||||||
LogPrint (eLogDebug, "NTCP2: SessionCreated received ", bytes_transferred);
|
boost::asio::post (m_Server.GetEstablisherService (),
|
||||||
uint16_t paddingLen = 0;
|
[s = shared_from_this (), bytes_transferred] ()
|
||||||
if (m_Establisher->ProcessSessionCreatedMessage (paddingLen))
|
|
||||||
{
|
|
||||||
if (paddingLen > 0)
|
|
||||||
{
|
{
|
||||||
if (paddingLen <= NTCP2_SESSION_CREATED_MAX_SIZE - 64) // session created is 287 bytes max
|
s->ProcessSessionCreated (bytes_transferred);
|
||||||
{
|
});
|
||||||
boost::asio::async_read (m_Socket, boost::asio::buffer(m_Establisher->m_SessionCreatedBuffer + 64, paddingLen), boost::asio::transfer_all (),
|
}
|
||||||
std::bind(&NTCP2Session::HandleSessionCreatedPaddingReceived, shared_from_this (), std::placeholders::_1, std::placeholders::_2));
|
}
|
||||||
}
|
|
||||||
else
|
void NTCP2Session::ProcessSessionCreated (size_t len)
|
||||||
{
|
{
|
||||||
LogPrint (eLogWarning, "NTCP2: SessionCreated padding length ", (int)paddingLen, " is too long");
|
LogPrint (eLogDebug, "NTCP2: SessionCreated received ", len);
|
||||||
Terminate ();
|
uint16_t paddingLen = 0;
|
||||||
}
|
if (m_Establisher->ProcessSessionCreatedMessage (paddingLen))
|
||||||
|
{
|
||||||
|
if (paddingLen > 0)
|
||||||
|
{
|
||||||
|
if (paddingLen <= NTCP2_SESSION_CREATED_MAX_SIZE - 64) // session created is 287 bytes max
|
||||||
|
{
|
||||||
|
boost::asio::async_read (m_Socket, boost::asio::buffer(m_Establisher->m_SessionCreatedBuffer + 64, paddingLen), boost::asio::transfer_all (),
|
||||||
|
std::bind(&NTCP2Session::HandleSessionCreatedPaddingReceived, shared_from_this (), std::placeholders::_1, std::placeholders::_2));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
SendSessionConfirmed ();
|
{
|
||||||
|
LogPrint (eLogWarning, "NTCP2: SessionCreated padding length ", (int)paddingLen, " is too long");
|
||||||
|
boost::asio::post (m_Server.GetService (), std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
SendSessionConfirmed ();
|
||||||
if (GetRemoteIdentity ())
|
}
|
||||||
i2p::data::netdb.SetUnreachable (GetRemoteIdentity ()->GetIdentHash (), true); // assume wrong s key
|
else
|
||||||
Terminate ();
|
{
|
||||||
}
|
if (GetRemoteIdentity ())
|
||||||
|
i2p::data::netdb.SetUnreachable (GetRemoteIdentity ()->GetIdentHash (), true); // assume wrong s key
|
||||||
|
boost::asio::post (m_Server.GetService (), std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -600,7 +623,11 @@ namespace transport
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_Establisher->m_SessionCreatedBufferLen += bytes_transferred;
|
m_Establisher->m_SessionCreatedBufferLen += bytes_transferred;
|
||||||
SendSessionConfirmed ();
|
boost::asio::post (m_Server.GetEstablisherService (),
|
||||||
|
[s = shared_from_this ()] ()
|
||||||
|
{
|
||||||
|
s->SendSessionConfirmed ();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -679,7 +706,7 @@ namespace transport
|
|||||||
// part 2
|
// part 2
|
||||||
std::vector<uint8_t> buf(m_Establisher->m3p2Len - 16); // -MAC
|
std::vector<uint8_t> buf(m_Establisher->m3p2Len - 16); // -MAC
|
||||||
memset (nonce, 0, 12); // set nonce to 0 again
|
memset (nonce, 0, 12); // set nonce to 0 again
|
||||||
if (m_Establisher->ProcessSessionConfirmedMessagePart2 (nonce, buf.data ()))
|
if (m_Establisher->ProcessSessionConfirmedMessagePart2 (nonce, buf.data ())) // TODO:handle in establisher thread
|
||||||
{
|
{
|
||||||
KeyDerivationFunctionDataPhase ();
|
KeyDerivationFunctionDataPhase ();
|
||||||
// Bob data phase keys
|
// Bob data phase keys
|
||||||
@@ -811,7 +838,11 @@ namespace transport
|
|||||||
void NTCP2Session::ClientLogin ()
|
void NTCP2Session::ClientLogin ()
|
||||||
{
|
{
|
||||||
m_Establisher->CreateEphemeralKey ();
|
m_Establisher->CreateEphemeralKey ();
|
||||||
SendSessionRequest ();
|
boost::asio::post (m_Server.GetEstablisherService (),
|
||||||
|
[s = shared_from_this ()] ()
|
||||||
|
{
|
||||||
|
s->SendSessionRequest ();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void NTCP2Session::ServerLogin ()
|
void NTCP2Session::ServerLogin ()
|
||||||
@@ -1367,6 +1398,7 @@ namespace transport
|
|||||||
|
|
||||||
void NTCP2Server::Start ()
|
void NTCP2Server::Start ()
|
||||||
{
|
{
|
||||||
|
m_EstablisherService.Start ();
|
||||||
if (!IsRunning ())
|
if (!IsRunning ())
|
||||||
{
|
{
|
||||||
StartIOService ();
|
StartIOService ();
|
||||||
@@ -1476,6 +1508,7 @@ namespace transport
|
|||||||
m_TerminationTimer.cancel ();
|
m_TerminationTimer.cancel ();
|
||||||
m_ProxyEndpoint = nullptr;
|
m_ProxyEndpoint = nullptr;
|
||||||
}
|
}
|
||||||
|
m_EstablisherService.Stop ();
|
||||||
StopIOService ();
|
StopIOService ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -172,9 +172,11 @@ namespace transport
|
|||||||
|
|
||||||
void HandleSessionRequestSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionRequestSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
void HandleSessionRequestReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionRequestReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
|
void ProcessSessionRequest (size_t len);
|
||||||
void HandleSessionRequestPaddingReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionRequestPaddingReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
void HandleSessionCreatedSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionCreatedSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
void HandleSessionCreatedReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionCreatedReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
|
void ProcessSessionCreated (size_t len);
|
||||||
void HandleSessionCreatedPaddingReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionCreatedPaddingReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
void HandleSessionConfirmedSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionConfirmedSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
void HandleSessionConfirmedReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSessionConfirmedReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
@@ -239,6 +241,18 @@ namespace transport
|
|||||||
|
|
||||||
class NTCP2Server: private i2p::util::RunnableServiceWithWork
|
class NTCP2Server: private i2p::util::RunnableServiceWithWork
|
||||||
{
|
{
|
||||||
|
private:
|
||||||
|
|
||||||
|
class EstablisherService: public i2p::util::RunnableServiceWithWork
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
EstablisherService (): RunnableServiceWithWork ("NTCP2e") {};
|
||||||
|
auto& GetService () { return GetIOService (); };
|
||||||
|
void Start () { StartIOService (); };
|
||||||
|
void Stop () { StopIOService (); };
|
||||||
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
enum ProxyType
|
enum ProxyType
|
||||||
@@ -254,6 +268,7 @@ namespace transport
|
|||||||
void Start ();
|
void Start ();
|
||||||
void Stop ();
|
void Stop ();
|
||||||
auto& GetService () { return GetIOService (); };
|
auto& GetService () { return GetIOService (); };
|
||||||
|
auto& GetEstablisherService () { return m_EstablisherService.GetService (); };
|
||||||
std::mt19937& GetRng () { return m_Rng; };
|
std::mt19937& GetRng () { return m_Rng; };
|
||||||
|
|
||||||
bool AddNTCP2Session (std::shared_ptr<NTCP2Session> session, bool incoming = false);
|
bool AddNTCP2Session (std::shared_ptr<NTCP2Session> session, bool incoming = false);
|
||||||
@@ -294,6 +309,7 @@ namespace transport
|
|||||||
std::unique_ptr<boost::asio::ip::tcp::endpoint> m_ProxyEndpoint;
|
std::unique_ptr<boost::asio::ip::tcp::endpoint> m_ProxyEndpoint;
|
||||||
std::shared_ptr<boost::asio::ip::tcp::endpoint> m_Address4, m_Address6, m_YggdrasilAddress;
|
std::shared_ptr<boost::asio::ip::tcp::endpoint> m_Address4, m_Address6, m_YggdrasilAddress;
|
||||||
std::mt19937 m_Rng;
|
std::mt19937 m_Rng;
|
||||||
|
EstablisherService m_EstablisherService;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user