mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-04-28 11:47:48 +02:00
handle and send termination
This commit is contained in:
parent
7d5f51e357
commit
a3f165d374
2 changed files with 59 additions and 14 deletions
|
@ -62,6 +62,23 @@ namespace transport
|
|||
SendTokenRequest ();
|
||||
}
|
||||
|
||||
void SSU2Session::Terminate ()
|
||||
{
|
||||
if (m_State != eSSU2SessionStateTerminated)
|
||||
{
|
||||
m_State = eSSU2SessionStateTerminated;
|
||||
transports.PeerDisconnected (shared_from_this ());
|
||||
m_Server.RemoveSession (m_SourceConnID);
|
||||
LogPrint (eLogDebug, "SSU2: Session terminated");
|
||||
}
|
||||
}
|
||||
|
||||
void SSU2Session::TerminateByTimeout ()
|
||||
{
|
||||
SendTermination ();
|
||||
m_Server.GetService ().post (std::bind (&SSU2Session::Terminate, shared_from_this ()));
|
||||
}
|
||||
|
||||
void SSU2Session::Established ()
|
||||
{
|
||||
m_State = eSSU2SessionStateEstablished;
|
||||
|
@ -129,7 +146,7 @@ namespace transport
|
|||
i2p::crypto::ChaCha20 (headerX, 48, m_Address->i, nonce, headerX);
|
||||
m_NoiseState->MixHash (payload, payloadSize); // h = SHA256(h || encrypted payload from Session Request) for SessionCreated
|
||||
// send
|
||||
m_Server.AddPendingOutgoingSession (m_RemoteEndpoint, shared_from_this ());
|
||||
m_Server.AddPendingOutgoingSession (shared_from_this ());
|
||||
m_Server.Send (header.buf, 16, headerX, 48, payload, payloadSize, m_RemoteEndpoint);
|
||||
}
|
||||
|
||||
|
@ -159,7 +176,7 @@ namespace transport
|
|||
// payload
|
||||
HandlePayload (decryptedPayload.data (), decryptedPayload.size ());
|
||||
|
||||
m_Server.AddSession (m_SourceConnID, shared_from_this ());
|
||||
m_Server.AddSession (shared_from_this ());
|
||||
SendSessionCreated (headerX + 16);
|
||||
}
|
||||
|
||||
|
@ -241,7 +258,7 @@ namespace transport
|
|||
// payload
|
||||
HandlePayload (decryptedPayload.data (), decryptedPayload.size ());
|
||||
|
||||
m_Server.AddSession (m_SourceConnID, shared_from_this ());
|
||||
m_Server.AddSession (shared_from_this ());
|
||||
SendSessionConfirmed (headerX + 16);
|
||||
KDFDataPhase (m_KeyDataSend, m_KeyDataReceive);
|
||||
Established ();
|
||||
|
@ -423,7 +440,7 @@ namespace transport
|
|||
header.ll[1] ^= CreateHeaderMask (m_Address->i, payload + (payloadSize - 12));
|
||||
i2p::crypto::ChaCha20 (h + 16, 16, m_Address->i, nonce, h + 16);
|
||||
// send
|
||||
m_Server.AddPendingOutgoingSession (m_RemoteEndpoint, shared_from_this ());
|
||||
m_Server.AddPendingOutgoingSession (shared_from_this ());
|
||||
m_Server.Send (header.buf, 16, h + 16, 16, payload, payloadSize, m_RemoteEndpoint);
|
||||
}
|
||||
|
||||
|
@ -620,6 +637,8 @@ namespace transport
|
|||
case eSSU2BlkFollowOnFragment:
|
||||
break;
|
||||
case eSSU2BlkTermination:
|
||||
LogPrint (eLogDebug, "SSU2: Termination");
|
||||
Terminate ();
|
||||
break;
|
||||
case eSSU2BlkRelayRequest:
|
||||
break;
|
||||
|
@ -781,6 +800,17 @@ namespace transport
|
|||
payloadSize += CreatePaddingBlock (payload + payloadSize, SSU2_MTU - payloadSize);
|
||||
SendData (payload, payloadSize);
|
||||
}
|
||||
|
||||
void SSU2Session::SendTermination ()
|
||||
{
|
||||
uint8_t payload[32];
|
||||
size_t payloadSize = 12;
|
||||
payload[0] = eSSU2BlkTermination;
|
||||
htobe16buf (payload + 1, 9);
|
||||
memset (payload + 3, 0, 9);
|
||||
payloadSize += CreatePaddingBlock (payload + payloadSize, 32 - payloadSize);
|
||||
SendData (payload, payloadSize);
|
||||
}
|
||||
|
||||
SSU2Server::SSU2Server ():
|
||||
RunnableServiceWithWork ("SSU2"), m_Socket (GetService ()), m_SocketV6 (GetService ()),
|
||||
|
@ -886,14 +916,21 @@ namespace transport
|
|||
}
|
||||
}
|
||||
|
||||
void SSU2Server::AddSession (uint64_t connID, std::shared_ptr<SSU2Session> session)
|
||||
void SSU2Server::AddSession (std::shared_ptr<SSU2Session> session)
|
||||
{
|
||||
m_Sessions.emplace (connID, session);
|
||||
if (session)
|
||||
m_Sessions.emplace (session->GetConnID (), session);
|
||||
}
|
||||
|
||||
void SSU2Server::AddPendingOutgoingSession (const boost::asio::ip::udp::endpoint& ep, std::shared_ptr<SSU2Session> session)
|
||||
void SSU2Server::RemoveSession (uint64_t connID)
|
||||
{
|
||||
m_PendingOutgoingSessions.emplace (ep, session);
|
||||
m_Sessions.erase (connID);
|
||||
}
|
||||
|
||||
void SSU2Server::AddPendingOutgoingSession (std::shared_ptr<SSU2Session> session)
|
||||
{
|
||||
if (session)
|
||||
m_PendingOutgoingSessions.emplace (session->GetRemoteEndpoint (), session);
|
||||
}
|
||||
|
||||
void SSU2Server::ProcessNextPacket (uint8_t * buf, size_t len, const boost::asio::ip::udp::endpoint& senderEndpoint)
|
||||
|
@ -1005,7 +1042,8 @@ namespace transport
|
|||
{
|
||||
if (it->second->IsTerminationTimeoutExpired (ts))
|
||||
{
|
||||
//it->second->Terminate ();
|
||||
if (it->second->IsEstablished ())
|
||||
it->second->TerminateByTimeout ();
|
||||
it = m_Sessions.erase (it);
|
||||
}
|
||||
else
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue