mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-04-27 19:27:49 +02:00
cleanup I2NP msgs pool and routing sessions
This commit is contained in:
parent
1410fa5c21
commit
8a3d6ddb3e
2 changed files with 20 additions and 0 deletions
|
@ -298,6 +298,12 @@ namespace client
|
|||
m_Owner->SendMessageStatusMessage (nonce, eI2CPMessageStatusGuaranteedSuccess);
|
||||
return sent;
|
||||
}
|
||||
|
||||
void I2CPDestination::CleanupDestination ()
|
||||
{
|
||||
m_I2NPMsgsPool.CleanUpMt ();
|
||||
if (m_Owner) m_Owner->CleanupRoutingSessions ();
|
||||
}
|
||||
|
||||
RunnableI2CPDestination::RunnableI2CPDestination (std::shared_ptr<I2CPSession> owner,
|
||||
std::shared_ptr<const i2p::data::IdentityEx> identity, bool isPublic, const std::map<std::string, std::string>& params):
|
||||
|
@ -756,6 +762,18 @@ namespace client
|
|||
std::lock_guard<std::mutex> l(m_RoutingSessionsMutex);
|
||||
m_RoutingSessions[signingKey] = remoteSession;
|
||||
}
|
||||
|
||||
void I2CPSession::CleanupRoutingSessions ()
|
||||
{
|
||||
std::lock_guard<std::mutex> l(m_RoutingSessionsMutex);
|
||||
for (auto it = m_RoutingSessions.begin (); it != m_RoutingSessions.end ();)
|
||||
{
|
||||
if (it->second->IsTerminated ())
|
||||
it = m_RoutingSessions.erase (it);
|
||||
else
|
||||
it++;
|
||||
}
|
||||
}
|
||||
|
||||
void I2CPSession::CreateLeaseSetMessageHandler (const uint8_t * buf, size_t len)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue