mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-10 16:37:54 +00:00
fixed potential race condition
This commit is contained in:
parent
12b9b49902
commit
9d292bb6a4
25
Garlic.cpp
25
Garlic.cpp
@ -650,37 +650,48 @@ namespace garlic
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// delivery status sessions
|
// delivery status sessions
|
||||||
for (auto it = m_DeliveryStatusSessions.begin (); it != m_DeliveryStatusSessions.end (); )
|
|
||||||
{
|
{
|
||||||
if (it->second->GetOwner () != this)
|
std::unique_lock<std::mutex> l(m_DeliveryStatusSessionsMutex);
|
||||||
it = m_DeliveryStatusSessions.erase (it);
|
for (auto it = m_DeliveryStatusSessions.begin (); it != m_DeliveryStatusSessions.end (); )
|
||||||
else
|
{
|
||||||
++it;
|
if (it->second->GetOwner () != this)
|
||||||
|
it = m_DeliveryStatusSessions.erase (it);
|
||||||
|
else
|
||||||
|
++it;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void GarlicDestination::RemoveDeliveryStatusSession (uint32_t msgID)
|
void GarlicDestination::RemoveDeliveryStatusSession (uint32_t msgID)
|
||||||
{
|
{
|
||||||
|
std::unique_lock<std::mutex> l(m_DeliveryStatusSessionsMutex);
|
||||||
m_DeliveryStatusSessions.erase (msgID);
|
m_DeliveryStatusSessions.erase (msgID);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GarlicDestination::DeliveryStatusSent (GarlicRoutingSessionPtr session, uint32_t msgID)
|
void GarlicDestination::DeliveryStatusSent (GarlicRoutingSessionPtr session, uint32_t msgID)
|
||||||
{
|
{
|
||||||
|
std::unique_lock<std::mutex> l(m_DeliveryStatusSessionsMutex);
|
||||||
m_DeliveryStatusSessions[msgID] = session;
|
m_DeliveryStatusSessions[msgID] = session;
|
||||||
}
|
}
|
||||||
|
|
||||||
void GarlicDestination::HandleDeliveryStatusMessage (std::shared_ptr<I2NPMessage> msg)
|
void GarlicDestination::HandleDeliveryStatusMessage (std::shared_ptr<I2NPMessage> msg)
|
||||||
{
|
{
|
||||||
uint32_t msgID = bufbe32toh (msg->GetPayload ());
|
uint32_t msgID = bufbe32toh (msg->GetPayload ());
|
||||||
|
GarlicRoutingSessionPtr session;
|
||||||
{
|
{
|
||||||
|
std::unique_lock<std::mutex> l(m_DeliveryStatusSessionsMutex);
|
||||||
auto it = m_DeliveryStatusSessions.find (msgID);
|
auto it = m_DeliveryStatusSessions.find (msgID);
|
||||||
if (it != m_DeliveryStatusSessions.end ())
|
if (it != m_DeliveryStatusSessions.end ())
|
||||||
{
|
{
|
||||||
it->second->MessageConfirmed (msgID);
|
session = it->second;
|
||||||
m_DeliveryStatusSessions.erase (it);
|
m_DeliveryStatusSessions.erase (it);
|
||||||
LogPrint (eLogDebug, "Garlic: message ", msgID, " acknowledged");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (session)
|
||||||
|
{
|
||||||
|
session->MessageConfirmed (msgID);
|
||||||
|
LogPrint (eLogDebug, "Garlic: message ", msgID, " acknowledged");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void GarlicDestination::SetLeaseSetUpdated ()
|
void GarlicDestination::SetLeaseSetUpdated ()
|
||||||
|
1
Garlic.h
1
Garlic.h
@ -195,6 +195,7 @@ namespace garlic
|
|||||||
// incoming
|
// incoming
|
||||||
std::map<SessionTag, std::shared_ptr<i2p::crypto::CBCDecryption>> m_Tags;
|
std::map<SessionTag, std::shared_ptr<i2p::crypto::CBCDecryption>> m_Tags;
|
||||||
// DeliveryStatus
|
// DeliveryStatus
|
||||||
|
std::mutex m_DeliveryStatusSessionsMutex;
|
||||||
std::map<uint32_t, GarlicRoutingSessionPtr> m_DeliveryStatusSessions; // msgID -> session
|
std::map<uint32_t, GarlicRoutingSessionPtr> m_DeliveryStatusSessions; // msgID -> session
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
Loading…
Reference in New Issue
Block a user