mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-10-17 09:10:21 +01:00
reply with acked option to datagram3 with seqn option
Some checks are pending
Build Debian packages / trixie (push) Waiting to run
Build Debian packages / bookworm (push) Waiting to run
Build Debian packages / bullseye (push) Waiting to run
Build on FreeBSD / with UPnP (push) Waiting to run
Build on OSX / With USE_UPNP=no (push) Waiting to run
Build on OSX / With USE_UPNP=yes (push) Waiting to run
Build on Windows / clang-x86_64 (push) Waiting to run
Build on Windows / i686 (push) Waiting to run
Build on Windows / ucrt-x86_64 (push) Waiting to run
Build on Windows / x86_64 (push) Waiting to run
Build on Windows / CMake clang-x86_64 (push) Waiting to run
Build on Windows / CMake i686 (push) Waiting to run
Build on Windows / CMake ucrt-x86_64 (push) Waiting to run
Build on Windows / CMake x86_64 (push) Waiting to run
Build on Windows / XP (push) Waiting to run
Build on Ubuntu / Make with USE_UPNP=no (push) Waiting to run
Build on Ubuntu / Make with USE_UPNP=yes (push) Waiting to run
Build on Ubuntu / CMake with -DWITH_UPNP=OFF (push) Waiting to run
Build on Ubuntu / CMake with -DWITH_UPNP=ON (push) Waiting to run
Build containers / Building container for linux/amd64 (push) Waiting to run
Build containers / Building container for linux/arm64 (push) Waiting to run
Build containers / Building container for linux/arm/v7 (push) Waiting to run
Build containers / Building container for linux/386 (push) Waiting to run
Build containers / Pushing merged manifest (push) Blocked by required conditions
Some checks are pending
Build Debian packages / trixie (push) Waiting to run
Build Debian packages / bookworm (push) Waiting to run
Build Debian packages / bullseye (push) Waiting to run
Build on FreeBSD / with UPnP (push) Waiting to run
Build on OSX / With USE_UPNP=no (push) Waiting to run
Build on OSX / With USE_UPNP=yes (push) Waiting to run
Build on Windows / clang-x86_64 (push) Waiting to run
Build on Windows / i686 (push) Waiting to run
Build on Windows / ucrt-x86_64 (push) Waiting to run
Build on Windows / x86_64 (push) Waiting to run
Build on Windows / CMake clang-x86_64 (push) Waiting to run
Build on Windows / CMake i686 (push) Waiting to run
Build on Windows / CMake ucrt-x86_64 (push) Waiting to run
Build on Windows / CMake x86_64 (push) Waiting to run
Build on Windows / XP (push) Waiting to run
Build on Ubuntu / Make with USE_UPNP=no (push) Waiting to run
Build on Ubuntu / Make with USE_UPNP=yes (push) Waiting to run
Build on Ubuntu / CMake with -DWITH_UPNP=OFF (push) Waiting to run
Build on Ubuntu / CMake with -DWITH_UPNP=ON (push) Waiting to run
Build containers / Building container for linux/amd64 (push) Waiting to run
Build containers / Building container for linux/arm64 (push) Waiting to run
Build containers / Building container for linux/arm/v7 (push) Waiting to run
Build containers / Building container for linux/386 (push) Waiting to run
Build containers / Pushing merged manifest (push) Blocked by required conditions
This commit is contained in:
parent
73bf24e897
commit
ba2cfe58bc
3 changed files with 45 additions and 17 deletions
|
@ -304,7 +304,6 @@ namespace datagram
|
||||||
auto session = ObtainSession (ident);
|
auto session = ObtainSession (ident);
|
||||||
session->SetVersion (eDatagramV3);
|
session->SetVersion (eDatagramV3);
|
||||||
session->SetRemoteLeaseSet (ls);
|
session->SetRemoteLeaseSet (ls);
|
||||||
session->Ack ();
|
|
||||||
auto r = FindReceiver(toPort);
|
auto r = FindReceiver(toPort);
|
||||||
if (r)
|
if (r)
|
||||||
{
|
{
|
||||||
|
@ -333,6 +332,7 @@ namespace datagram
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogWarning, "Datagram: no receiver for port ", toPort);
|
LogPrint (eLogWarning, "Datagram: no receiver for port ", toPort);
|
||||||
|
session->Ack ();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "Datagram: Remote LeaseSet static key mismatch for datagram3 from ", ident.ToBase32 ());
|
LogPrint (eLogError, "Datagram: Remote LeaseSet static key mismatch for datagram3 from ", ident.ToBase32 ());
|
||||||
|
|
|
@ -26,7 +26,8 @@ namespace client
|
||||||
if (!m_LastSession || m_LastSession->Identity.GetLL()[0] != from.GetIdentHash ().GetLL()[0] || fromPort != m_LastSession->RemotePort)
|
if (!m_LastSession || m_LastSession->Identity.GetLL()[0] != from.GetIdentHash ().GetLL()[0] || fromPort != m_LastSession->RemotePort)
|
||||||
m_LastSession = ObtainUDPSession(from, toPort, fromPort);
|
m_LastSession = ObtainUDPSession(from, toPort, fromPort);
|
||||||
boost::system::error_code ec;
|
boost::system::error_code ec;
|
||||||
m_LastSession->IPSocket.send_to(boost::asio::buffer(buf, len), m_RemoteEndpoint, 0, ec);
|
if (len > 0)
|
||||||
|
m_LastSession->IPSocket.send_to(boost::asio::buffer(buf, len), m_RemoteEndpoint, 0, ec);
|
||||||
if (!ec)
|
if (!ec)
|
||||||
m_LastSession->LastActivity = i2p::util::GetMillisecondsSinceEpoch();
|
m_LastSession->LastActivity = i2p::util::GetMillisecondsSinceEpoch();
|
||||||
else
|
else
|
||||||
|
@ -35,7 +36,13 @@ namespace client
|
||||||
{
|
{
|
||||||
uint32_t seqn = 0;
|
uint32_t seqn = 0;
|
||||||
if (options->Get (UDP_SESSION_SEQN, seqn) && seqn > m_LastSession->m_LastReceivedPacketNum)
|
if (options->Get (UDP_SESSION_SEQN, seqn) && seqn > m_LastSession->m_LastReceivedPacketNum)
|
||||||
|
{
|
||||||
m_LastSession->m_LastReceivedPacketNum = seqn;
|
m_LastSession->m_LastReceivedPacketNum = seqn;
|
||||||
|
i2p::util::Mapping options;
|
||||||
|
options.Put (UDP_SESSION_ACKED, m_LastSession->m_LastReceivedPacketNum);
|
||||||
|
m_LastSession->m_Destination->SendDatagram(m_LastSession->GetDatagramSession (),
|
||||||
|
nullptr, 0, m_LastSession->LocalPort, m_LastSession->RemotePort, &options); // Ack only, no payload
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -141,7 +148,7 @@ namespace client
|
||||||
IPSocket.non_blocking (true);
|
IPSocket.non_blocking (true);
|
||||||
Receive();
|
Receive();
|
||||||
}
|
}
|
||||||
|
|
||||||
void UDPSession::Receive()
|
void UDPSession::Receive()
|
||||||
{
|
{
|
||||||
LogPrint(eLogDebug, "UDPSession: Receive");
|
LogPrint(eLogDebug, "UDPSession: Receive");
|
||||||
|
@ -155,12 +162,7 @@ namespace client
|
||||||
{
|
{
|
||||||
LogPrint(eLogDebug, "UDPSession: Forward ", len, "B from ", FromEndpoint);
|
LogPrint(eLogDebug, "UDPSession: Forward ", len, "B from ", FromEndpoint);
|
||||||
auto ts = i2p::util::GetMillisecondsSinceEpoch();
|
auto ts = i2p::util::GetMillisecondsSinceEpoch();
|
||||||
auto session = m_LastDatagramSession.lock ();
|
auto session = GetDatagramSession ();
|
||||||
if (!session)
|
|
||||||
{
|
|
||||||
session = m_Destination->GetSession (Identity);
|
|
||||||
m_LastDatagramSession = session;
|
|
||||||
}
|
|
||||||
if (ts > LastActivity + I2P_UDP_REPLIABLE_DATAGRAM_INTERVAL)
|
if (ts > LastActivity + I2P_UDP_REPLIABLE_DATAGRAM_INTERVAL)
|
||||||
{
|
{
|
||||||
i2p::util::Mapping options;
|
i2p::util::Mapping options;
|
||||||
|
@ -192,6 +194,17 @@ namespace client
|
||||||
LogPrint(eLogError, "UDPSession: ", ecode.message());
|
LogPrint(eLogError, "UDPSession: ", ecode.message());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::shared_ptr<i2p::datagram::DatagramSession> UDPSession::GetDatagramSession ()
|
||||||
|
{
|
||||||
|
auto session = m_LastDatagramSession.lock ();
|
||||||
|
if (!session)
|
||||||
|
{
|
||||||
|
session = m_Destination->GetSession (Identity);
|
||||||
|
m_LastDatagramSession = session;
|
||||||
|
}
|
||||||
|
return session;
|
||||||
|
}
|
||||||
|
|
||||||
I2PUDPServerTunnel::I2PUDPServerTunnel (const std::string & name, std::shared_ptr<i2p::client::ClientDestination> localDestination,
|
I2PUDPServerTunnel::I2PUDPServerTunnel (const std::string & name, std::shared_ptr<i2p::client::ClientDestination> localDestination,
|
||||||
const boost::asio::ip::address& localAddress, const boost::asio::ip::udp::endpoint& forwardTo, uint16_t inPort, bool gzip) :
|
const boost::asio::ip::address& localAddress, const boost::asio::ip::udp::endpoint& forwardTo, uint16_t inPort, bool gzip) :
|
||||||
m_IsUniqueLocal (true), m_Name (name), m_LocalAddress (localAddress),
|
m_IsUniqueLocal (true), m_Name (name), m_LocalAddress (localAddress),
|
||||||
|
@ -358,12 +371,7 @@ namespace client
|
||||||
// send off to remote i2p destination
|
// send off to remote i2p destination
|
||||||
auto ts = i2p::util::GetMillisecondsSinceEpoch ();
|
auto ts = i2p::util::GetMillisecondsSinceEpoch ();
|
||||||
LogPrint (eLogDebug, "UDP Client: Send ", transferred, " to ", m_RemoteAddr->identHash.ToBase32 (), ":", RemotePort);
|
LogPrint (eLogDebug, "UDP Client: Send ", transferred, " to ", m_RemoteAddr->identHash.ToBase32 (), ":", RemotePort);
|
||||||
auto session = m_LastDatagramSession.lock ();
|
auto session = GetDatagramSession ();
|
||||||
if (!session)
|
|
||||||
{
|
|
||||||
session = m_LocalDest->GetDatagramDestination ()->GetSession (m_RemoteAddr->identHash);
|
|
||||||
m_LastDatagramSession = session;
|
|
||||||
}
|
|
||||||
if (ts > m_LastSession->second + I2P_UDP_REPLIABLE_DATAGRAM_INTERVAL)
|
if (ts > m_LastSession->second + I2P_UDP_REPLIABLE_DATAGRAM_INTERVAL)
|
||||||
{
|
{
|
||||||
i2p::util::Mapping options;
|
i2p::util::Mapping options;
|
||||||
|
@ -427,6 +435,17 @@ namespace client
|
||||||
LogPrint(eLogInfo, "UDP Tunnel: Resolved ", m_RemoteDest, " to ", m_RemoteAddr->identHash.ToBase32 ());
|
LogPrint(eLogInfo, "UDP Tunnel: Resolved ", m_RemoteDest, " to ", m_RemoteAddr->identHash.ToBase32 ());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::shared_ptr<i2p::datagram::DatagramSession> I2PUDPClientTunnel::GetDatagramSession ()
|
||||||
|
{
|
||||||
|
auto session = m_LastDatagramSession.lock ();
|
||||||
|
if (!session)
|
||||||
|
{
|
||||||
|
session = m_LocalDest->GetDatagramDestination ()->GetSession (m_RemoteAddr->identHash);
|
||||||
|
m_LastDatagramSession = session;
|
||||||
|
}
|
||||||
|
return session;
|
||||||
|
}
|
||||||
|
|
||||||
void I2PUDPClientTunnel::HandleRecvFromI2P (const i2p::data::IdentityEx& from, uint16_t fromPort, uint16_t toPort,
|
void I2PUDPClientTunnel::HandleRecvFromI2P (const i2p::data::IdentityEx& from, uint16_t fromPort, uint16_t toPort,
|
||||||
const uint8_t * buf, size_t len, const i2p::util::Mapping * options)
|
const uint8_t * buf, size_t len, const i2p::util::Mapping * options)
|
||||||
{
|
{
|
||||||
|
@ -436,9 +455,16 @@ namespace client
|
||||||
{
|
{
|
||||||
uint32_t seqn = 0;
|
uint32_t seqn = 0;
|
||||||
if (options->Get (UDP_SESSION_SEQN, seqn) && seqn > m_LastReceivedPacketNum)
|
if (options->Get (UDP_SESSION_SEQN, seqn) && seqn > m_LastReceivedPacketNum)
|
||||||
|
{
|
||||||
m_LastReceivedPacketNum = seqn;
|
m_LastReceivedPacketNum = seqn;
|
||||||
}
|
i2p::util::Mapping options;
|
||||||
HandleRecvFromI2PRaw (fromPort, toPort, buf, len);
|
options.Put (UDP_SESSION_ACKED, m_LastReceivedPacketNum);
|
||||||
|
m_LocalDest->GetDatagramDestination ()->SendDatagram (GetDatagramSession (),
|
||||||
|
nullptr, 0, m_LastPort, RemotePort, &options); // Ack only, no payload
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (len > 0)
|
||||||
|
HandleRecvFromI2PRaw (fromPort, toPort, buf, len);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint(eLogWarning, "UDP Client: Unwarranted traffic from ", from.GetIdentHash().ToBase32 ());
|
LogPrint(eLogWarning, "UDP Client: Unwarranted traffic from ", from.GetIdentHash().ToBase32 ());
|
||||||
|
|
|
@ -55,6 +55,7 @@ namespace client
|
||||||
uint16_t ourPort, uint16_t theirPort);
|
uint16_t ourPort, uint16_t theirPort);
|
||||||
void HandleReceived(const boost::system::error_code & ecode, std::size_t len);
|
void HandleReceived(const boost::system::error_code & ecode, std::size_t len);
|
||||||
void Receive();
|
void Receive();
|
||||||
|
std::shared_ptr<i2p::datagram::DatagramSession> GetDatagramSession ();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -163,6 +164,7 @@ namespace client
|
||||||
const uint8_t * buf, size_t len, const i2p::util::Mapping * options);
|
const uint8_t * buf, size_t len, const i2p::util::Mapping * options);
|
||||||
void HandleRecvFromI2PRaw (uint16_t fromPort, uint16_t toPort, const uint8_t * buf, size_t len);
|
void HandleRecvFromI2PRaw (uint16_t fromPort, uint16_t toPort, const uint8_t * buf, size_t len);
|
||||||
void TryResolving ();
|
void TryResolving ();
|
||||||
|
std::shared_ptr<i2p::datagram::DatagramSession> GetDatagramSession ();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue