mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-02-02 02:44:15 +00:00
fixed races condition with pending outgoing sessions
This commit is contained in:
parent
eb0ef80a17
commit
629c718527
@ -368,6 +368,7 @@ namespace transport
|
|||||||
bool SSU2Server::AddPendingOutgoingSession (std::shared_ptr<SSU2Session> session)
|
bool SSU2Server::AddPendingOutgoingSession (std::shared_ptr<SSU2Session> session)
|
||||||
{
|
{
|
||||||
if (!session) return false;
|
if (!session) return false;
|
||||||
|
std::unique_lock<std::mutex> l(m_PendingOutgoingSessionsMutex);
|
||||||
return m_PendingOutgoingSessions.emplace (session->GetRemoteEndpoint (), session).second;
|
return m_PendingOutgoingSessions.emplace (session->GetRemoteEndpoint (), session).second;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -381,6 +382,7 @@ namespace transport
|
|||||||
|
|
||||||
std::shared_ptr<SSU2Session> SSU2Server::FindPendingOutgoingSession (const boost::asio::ip::udp::endpoint& ep) const
|
std::shared_ptr<SSU2Session> SSU2Server::FindPendingOutgoingSession (const boost::asio::ip::udp::endpoint& ep) const
|
||||||
{
|
{
|
||||||
|
std::unique_lock<std::mutex> l(m_PendingOutgoingSessionsMutex);
|
||||||
auto it = m_PendingOutgoingSessions.find (ep);
|
auto it = m_PendingOutgoingSessions.find (ep);
|
||||||
if (it != m_PendingOutgoingSessions.end ())
|
if (it != m_PendingOutgoingSessions.end ())
|
||||||
return it->second;
|
return it->second;
|
||||||
@ -389,6 +391,7 @@ namespace transport
|
|||||||
|
|
||||||
void SSU2Server::RemovePendingOutgoingSession (const boost::asio::ip::udp::endpoint& ep)
|
void SSU2Server::RemovePendingOutgoingSession (const boost::asio::ip::udp::endpoint& ep)
|
||||||
{
|
{
|
||||||
|
std::unique_lock<std::mutex> l(m_PendingOutgoingSessionsMutex);
|
||||||
m_PendingOutgoingSessions.erase (ep);
|
m_PendingOutgoingSessions.erase (ep);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -510,7 +513,10 @@ namespace transport
|
|||||||
{
|
{
|
||||||
if (it1->second->GetState () == eSSU2SessionStateSessionRequestSent &&
|
if (it1->second->GetState () == eSSU2SessionStateSessionRequestSent &&
|
||||||
it1->second->ProcessSessionCreated (buf, len))
|
it1->second->ProcessSessionCreated (buf, len))
|
||||||
|
{
|
||||||
|
std::unique_lock<std::mutex> l(m_PendingOutgoingSessionsMutex);
|
||||||
m_PendingOutgoingSessions.erase (it1); // we are done with that endpoint
|
m_PendingOutgoingSessions.erase (it1); // we are done with that endpoint
|
||||||
|
}
|
||||||
else
|
else
|
||||||
it1->second->ProcessRetry (buf, len);
|
it1->second->ProcessRetry (buf, len);
|
||||||
}
|
}
|
||||||
@ -754,6 +760,7 @@ namespace transport
|
|||||||
if (it->second->IsTerminationTimeoutExpired (ts))
|
if (it->second->IsTerminationTimeoutExpired (ts))
|
||||||
{
|
{
|
||||||
//it->second->Terminate ();
|
//it->second->Terminate ();
|
||||||
|
std::unique_lock<std::mutex> l(m_PendingOutgoingSessionsMutex);
|
||||||
it = m_PendingOutgoingSessions.erase (it);
|
it = m_PendingOutgoingSessions.erase (it);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#define SSU2_H__
|
#define SSU2_H__
|
||||||
|
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
#include <mutex>
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "SSU2Session.h"
|
#include "SSU2Session.h"
|
||||||
|
|
||||||
@ -140,6 +141,7 @@ namespace transport
|
|||||||
std::unordered_map<uint64_t, std::shared_ptr<SSU2Session> > m_Sessions;
|
std::unordered_map<uint64_t, std::shared_ptr<SSU2Session> > m_Sessions;
|
||||||
std::unordered_map<i2p::data::IdentHash, std::shared_ptr<SSU2Session> > m_SessionsByRouterHash;
|
std::unordered_map<i2p::data::IdentHash, std::shared_ptr<SSU2Session> > m_SessionsByRouterHash;
|
||||||
std::map<boost::asio::ip::udp::endpoint, std::shared_ptr<SSU2Session> > m_PendingOutgoingSessions;
|
std::map<boost::asio::ip::udp::endpoint, std::shared_ptr<SSU2Session> > m_PendingOutgoingSessions;
|
||||||
|
mutable std::mutex m_PendingOutgoingSessionsMutex;
|
||||||
std::map<boost::asio::ip::udp::endpoint, std::pair<uint64_t, uint32_t> > m_IncomingTokens, m_OutgoingTokens; // remote endpoint -> (token, expires in seconds)
|
std::map<boost::asio::ip::udp::endpoint, std::pair<uint64_t, uint32_t> > m_IncomingTokens, m_OutgoingTokens; // remote endpoint -> (token, expires in seconds)
|
||||||
std::map<uint32_t, std::shared_ptr<SSU2Session> > m_Relays; // we are introducer, relay tag -> session
|
std::map<uint32_t, std::shared_ptr<SSU2Session> > m_Relays; // we are introducer, relay tag -> session
|
||||||
std::list<i2p::data::IdentHash> m_Introducers, m_IntroducersV6; // introducers we are connected to
|
std::list<i2p::data::IdentHash> m_Introducers, m_IntroducersV6; // introducers we are connected to
|
||||||
|
Loading…
x
Reference in New Issue
Block a user