mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 21:37:17 +01:00
I2NPMessagesHandler
This commit is contained in:
parent
3ed1fee7ce
commit
0c73aff0a2
|
@ -579,4 +579,32 @@ namespace i2p
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
I2NPMessagesHandler::~I2NPMessagesHandler ()
|
||||||
|
{
|
||||||
|
Flush ();
|
||||||
|
}
|
||||||
|
|
||||||
|
void I2NPMessagesHandler::PutNextMessage (I2NPMessage * msg)
|
||||||
|
{
|
||||||
|
if (msg)
|
||||||
|
{
|
||||||
|
if (msg->GetTypeID () == eI2NPTunnelData)
|
||||||
|
{
|
||||||
|
LogPrint ("TunnelData");
|
||||||
|
m_TunnelMsgs.push_back (msg);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
HandleI2NPMessage (msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void I2NPMessagesHandler::Flush ()
|
||||||
|
{
|
||||||
|
if (!m_TunnelMsgs.empty ())
|
||||||
|
{
|
||||||
|
i2p::tunnel::tunnels.PostTunnelData (m_TunnelMsgs);
|
||||||
|
m_TunnelMsgs.clear ();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -216,6 +216,19 @@ namespace tunnel
|
||||||
size_t GetI2NPMessageLength (const uint8_t * msg);
|
size_t GetI2NPMessageLength (const uint8_t * msg);
|
||||||
void HandleI2NPMessage (uint8_t * msg, size_t len);
|
void HandleI2NPMessage (uint8_t * msg, size_t len);
|
||||||
void HandleI2NPMessage (I2NPMessage * msg);
|
void HandleI2NPMessage (I2NPMessage * msg);
|
||||||
|
|
||||||
|
class I2NPMessagesHandler
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
~I2NPMessagesHandler ();
|
||||||
|
void PutNextMessage (I2NPMessage * msg);
|
||||||
|
void Flush ();
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
std::vector<I2NPMessage *> m_TunnelMsgs;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -481,6 +481,7 @@ namespace transport
|
||||||
}
|
}
|
||||||
if (m_ReceiveBufferOffset > 0)
|
if (m_ReceiveBufferOffset > 0)
|
||||||
memcpy (m_ReceiveBuffer, nextBlock, m_ReceiveBufferOffset);
|
memcpy (m_ReceiveBuffer, nextBlock, m_ReceiveBufferOffset);
|
||||||
|
m_Handler.Flush ();
|
||||||
}
|
}
|
||||||
|
|
||||||
ScheduleTermination (); // reset termination timer
|
ScheduleTermination (); // reset termination timer
|
||||||
|
@ -529,7 +530,7 @@ namespace transport
|
||||||
if (m_NextMessageOffset >= m_NextMessage->len + 4) // +checksum
|
if (m_NextMessageOffset >= m_NextMessage->len + 4) // +checksum
|
||||||
{
|
{
|
||||||
// we have a complete I2NP message
|
// we have a complete I2NP message
|
||||||
i2p::HandleI2NPMessage (m_NextMessage);
|
m_Handler.PutNextMessage (m_NextMessage);
|
||||||
m_NextMessage = nullptr;
|
m_NextMessage = nullptr;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -42,7 +42,7 @@ namespace transport
|
||||||
#pragma pack()
|
#pragma pack()
|
||||||
|
|
||||||
const size_t NTCP_MAX_MESSAGE_SIZE = 16384;
|
const size_t NTCP_MAX_MESSAGE_SIZE = 16384;
|
||||||
const size_t NTCP_BUFFER_SIZE = 1040; // fits one tunnel message (1028)
|
const size_t NTCP_BUFFER_SIZE = 4160; // fits 4 tunnel messages (4*1028)
|
||||||
const int NTCP_TERMINATION_TIMEOUT = 120; // 2 minutes
|
const int NTCP_TERMINATION_TIMEOUT = 120; // 2 minutes
|
||||||
const size_t NTCP_DEFAULT_PHASE3_SIZE = 2/*size*/ + i2p::data::DEFAULT_IDENTITY_SIZE/*387*/ + 4/*ts*/ + 15/*padding*/ + 40/*signature*/; // 448
|
const size_t NTCP_DEFAULT_PHASE3_SIZE = 2/*size*/ + i2p::data::DEFAULT_IDENTITY_SIZE/*387*/ + 4/*ts*/ + 15/*padding*/ + 40/*signature*/; // 448
|
||||||
|
|
||||||
|
@ -131,7 +131,8 @@ namespace transport
|
||||||
|
|
||||||
i2p::I2NPMessage * m_NextMessage;
|
i2p::I2NPMessage * m_NextMessage;
|
||||||
size_t m_NextMessageOffset;
|
size_t m_NextMessageOffset;
|
||||||
|
i2p::I2NPMessagesHandler m_Handler;
|
||||||
|
|
||||||
size_t m_NumSentBytes, m_NumReceivedBytes;
|
size_t m_NumSentBytes, m_NumReceivedBytes;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
12
Queue.h
12
Queue.h
|
@ -2,6 +2,7 @@
|
||||||
#define QUEUE_H__
|
#define QUEUE_H__
|
||||||
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
#include <vector>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
#include <condition_variable>
|
#include <condition_variable>
|
||||||
|
@ -23,6 +24,17 @@ namespace util
|
||||||
m_NonEmpty.notify_one ();
|
m_NonEmpty.notify_one ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Put (const std::vector<Element *>& vec)
|
||||||
|
{
|
||||||
|
if (!vec.empty ())
|
||||||
|
{
|
||||||
|
std::unique_lock<std::mutex> l(m_QueueMutex);
|
||||||
|
for (auto it: vec)
|
||||||
|
m_Queue.push (it);
|
||||||
|
m_NonEmpty.notify_one ();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Element * GetNext ()
|
Element * GetNext ()
|
||||||
{
|
{
|
||||||
std::unique_lock<std::mutex> l(m_QueueMutex);
|
std::unique_lock<std::mutex> l(m_QueueMutex);
|
||||||
|
|
|
@ -576,6 +576,11 @@ namespace tunnel
|
||||||
if (msg) m_Queue.Put (msg);
|
if (msg) m_Queue.Put (msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Tunnels::PostTunnelData (const std::vector<I2NPMessage *>& msgs)
|
||||||
|
{
|
||||||
|
m_Queue.Put (msgs);
|
||||||
|
}
|
||||||
|
|
||||||
template<class TTunnel>
|
template<class TTunnel>
|
||||||
TTunnel * Tunnels::CreateTunnel (TunnelConfig * config, OutboundTunnel * outboundTunnel)
|
TTunnel * Tunnels::CreateTunnel (TunnelConfig * config, OutboundTunnel * outboundTunnel)
|
||||||
{
|
{
|
||||||
|
|
1
Tunnel.h
1
Tunnel.h
|
@ -130,6 +130,7 @@ namespace tunnel
|
||||||
void AddOutboundTunnel (OutboundTunnel * newTunnel);
|
void AddOutboundTunnel (OutboundTunnel * newTunnel);
|
||||||
void AddInboundTunnel (InboundTunnel * newTunnel);
|
void AddInboundTunnel (InboundTunnel * newTunnel);
|
||||||
void PostTunnelData (I2NPMessage * msg);
|
void PostTunnelData (I2NPMessage * msg);
|
||||||
|
void PostTunnelData (const std::vector<I2NPMessage *>& msgs);
|
||||||
template<class TTunnel>
|
template<class TTunnel>
|
||||||
TTunnel * CreateTunnel (TunnelConfig * config, OutboundTunnel * outboundTunnel = 0);
|
TTunnel * CreateTunnel (TunnelConfig * config, OutboundTunnel * outboundTunnel = 0);
|
||||||
std::shared_ptr<TunnelPool> CreateTunnelPool (i2p::garlic::GarlicDestination * localDestination, int numInboundHops, int numOuboundHops);
|
std::shared_ptr<TunnelPool> CreateTunnelPool (i2p::garlic::GarlicDestination * localDestination, int numInboundHops, int numOuboundHops);
|
||||||
|
|
Loading…
Reference in a new issue