mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 12:24:19 +00:00
send bulk datagrams
This commit is contained in:
parent
221c14cf0e
commit
6d7847f2df
@ -56,6 +56,11 @@ namespace datagram
|
|||||||
session->SendMsg(msg);
|
session->SendMsg(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DatagramDestination::FlushSendQueue (const i2p::data::IdentHash & ident)
|
||||||
|
{
|
||||||
|
ObtainSession(ident)->FlushSendQueue ();
|
||||||
|
}
|
||||||
|
|
||||||
void DatagramDestination::HandleDatagram (uint16_t fromPort, uint16_t toPort,uint8_t * const &buf, size_t len)
|
void DatagramDestination::HandleDatagram (uint16_t fromPort, uint16_t toPort,uint8_t * const &buf, size_t len)
|
||||||
{
|
{
|
||||||
i2p::data::IdentityEx identity;
|
i2p::data::IdentityEx identity;
|
||||||
@ -366,6 +371,7 @@ namespace datagram
|
|||||||
|
|
||||||
void DatagramSession::FlushSendQueue ()
|
void DatagramSession::FlushSendQueue ()
|
||||||
{
|
{
|
||||||
|
if (m_SendQueue.empty ()) return;
|
||||||
std::vector<i2p::tunnel::TunnelMessageBlock> send;
|
std::vector<i2p::tunnel::TunnelMessageBlock> send;
|
||||||
auto routingPath = GetSharedRoutingPath();
|
auto routingPath = GetSharedRoutingPath();
|
||||||
// if we don't have a routing path we will drop all queued messages
|
// if we don't have a routing path we will drop all queued messages
|
||||||
@ -380,7 +386,6 @@ namespace datagram
|
|||||||
routingPath->outboundTunnel->SendTunnelDataMsg(send);
|
routingPath->outboundTunnel->SendTunnelDataMsg(send);
|
||||||
}
|
}
|
||||||
m_SendQueue.clear();
|
m_SendQueue.clear();
|
||||||
ScheduleFlushSendQueue();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatagramSession::ScheduleFlushSendQueue()
|
void DatagramSession::ScheduleFlushSendQueue()
|
||||||
@ -388,7 +393,12 @@ namespace datagram
|
|||||||
boost::posix_time::milliseconds dlt(10);
|
boost::posix_time::milliseconds dlt(10);
|
||||||
m_SendQueueTimer.expires_from_now(dlt);
|
m_SendQueueTimer.expires_from_now(dlt);
|
||||||
auto self = shared_from_this();
|
auto self = shared_from_this();
|
||||||
m_SendQueueTimer.async_wait([self](const boost::system::error_code & ec) { if(ec) return; self->FlushSendQueue(); });
|
m_SendQueueTimer.async_wait([self](const boost::system::error_code & ec)
|
||||||
|
{
|
||||||
|
if(ec) return;
|
||||||
|
self->FlushSendQueue();
|
||||||
|
self->ScheduleFlushSendQueue();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,6 +59,7 @@ namespace datagram
|
|||||||
|
|
||||||
/** send an i2np message to remote endpoint for this session */
|
/** send an i2np message to remote endpoint for this session */
|
||||||
void SendMsg(std::shared_ptr<I2NPMessage> msg);
|
void SendMsg(std::shared_ptr<I2NPMessage> msg);
|
||||||
|
void FlushSendQueue();
|
||||||
/** get the last time in milliseconds for when we used this datagram session */
|
/** get the last time in milliseconds for when we used this datagram session */
|
||||||
uint64_t LastActivity() const { return m_LastUse; }
|
uint64_t LastActivity() const { return m_LastUse; }
|
||||||
|
|
||||||
@ -84,7 +85,6 @@ namespace datagram
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void FlushSendQueue();
|
|
||||||
void ScheduleFlushSendQueue();
|
void ScheduleFlushSendQueue();
|
||||||
|
|
||||||
void HandleSend(std::shared_ptr<I2NPMessage> msg);
|
void HandleSend(std::shared_ptr<I2NPMessage> msg);
|
||||||
@ -122,6 +122,7 @@ namespace datagram
|
|||||||
|
|
||||||
void SendDatagramTo (const uint8_t * payload, size_t len, const i2p::data::IdentHash & ident, uint16_t fromPort = 0, uint16_t toPort = 0);
|
void SendDatagramTo (const uint8_t * payload, size_t len, const i2p::data::IdentHash & ident, uint16_t fromPort = 0, uint16_t toPort = 0);
|
||||||
void SendRawDatagramTo (const uint8_t * payload, size_t len, const i2p::data::IdentHash & ident, uint16_t fromPort = 0, uint16_t toPort = 0);
|
void SendRawDatagramTo (const uint8_t * payload, size_t len, const i2p::data::IdentHash & ident, uint16_t fromPort = 0, uint16_t toPort = 0);
|
||||||
|
void FlushSendQueue (const i2p::data::IdentHash & ident);
|
||||||
void HandleDataMessagePayload (uint16_t fromPort, uint16_t toPort, const uint8_t * buf, size_t len, bool isRaw = false);
|
void HandleDataMessagePayload (uint16_t fromPort, uint16_t toPort, const uint8_t * buf, size_t len, bool isRaw = false);
|
||||||
|
|
||||||
void SetReceiver (const Receiver& receiver) { m_Receiver = receiver; };
|
void SetReceiver (const Receiver& receiver) { m_Receiver = receiver; };
|
||||||
|
@ -811,6 +811,24 @@ namespace client
|
|||||||
// send off to remote i2p destination
|
// send off to remote i2p destination
|
||||||
LogPrint(eLogDebug, "UDP Client: send ", transferred, " to ", m_RemoteIdent->ToBase32(), ":", RemotePort);
|
LogPrint(eLogDebug, "UDP Client: send ", transferred, " to ", m_RemoteIdent->ToBase32(), ":", RemotePort);
|
||||||
m_LocalDest->GetDatagramDestination()->SendDatagramTo(m_RecvBuff, transferred, *m_RemoteIdent, remotePort, RemotePort);
|
m_LocalDest->GetDatagramDestination()->SendDatagramTo(m_RecvBuff, transferred, *m_RemoteIdent, remotePort, RemotePort);
|
||||||
|
size_t numPackets = 0;
|
||||||
|
while (numPackets < i2p::datagram::DATAGRAM_SEND_QUEUE_MAX_SIZE)
|
||||||
|
{
|
||||||
|
boost::system::error_code ec;
|
||||||
|
size_t moreBytes = m_LocalSocket.available(ec);
|
||||||
|
if (ec || !moreBytes) break;
|
||||||
|
transferred = m_LocalSocket.receive_from (boost::asio::buffer (m_RecvBuff, I2P_UDP_MAX_MTU), m_RecvEndpoint, 0, ec);
|
||||||
|
remotePort = m_RecvEndpoint.port();
|
||||||
|
// TODO: check remotePort
|
||||||
|
m_LocalDest->GetDatagramDestination()->SendDatagramTo(m_RecvBuff, transferred, *m_RemoteIdent, remotePort, RemotePort);
|
||||||
|
numPackets++;
|
||||||
|
}
|
||||||
|
if (numPackets)
|
||||||
|
{
|
||||||
|
LogPrint(eLogDebug, "UDP Client: sent ", numPackets, " more packets to ", m_RemoteIdent->ToBase32());
|
||||||
|
m_LocalDest->GetDatagramDestination()->FlushSendQueue (*m_RemoteIdent);
|
||||||
|
}
|
||||||
|
|
||||||
// mark convo as active
|
// mark convo as active
|
||||||
if (m_LastSession)
|
if (m_LastSession)
|
||||||
m_LastSession->second = i2p::util::GetMillisecondsSinceEpoch();
|
m_LastSession->second = i2p::util::GetMillisecondsSinceEpoch();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user