mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-23 21:44:15 +00:00
fixed zero-hops tunnels
This commit is contained in:
parent
f6e988d6fd
commit
c50105493a
@ -31,7 +31,7 @@ namespace client
|
|||||||
{
|
{
|
||||||
|
|
||||||
int len = i2p::util::lexical_cast<int>(it->second, inboundTunnelLen);
|
int len = i2p::util::lexical_cast<int>(it->second, inboundTunnelLen);
|
||||||
if (len > 0)
|
if (len >= 0)
|
||||||
{
|
{
|
||||||
inboundTunnelLen = len;
|
inboundTunnelLen = len;
|
||||||
}
|
}
|
||||||
@ -42,7 +42,7 @@ namespace client
|
|||||||
{
|
{
|
||||||
|
|
||||||
int len = i2p::util::lexical_cast<int>(it->second, outboundTunnelLen);
|
int len = i2p::util::lexical_cast<int>(it->second, outboundTunnelLen);
|
||||||
if (len > 0)
|
if (len >= 0)
|
||||||
{
|
{
|
||||||
outboundTunnelLen = len;
|
outboundTunnelLen = len;
|
||||||
}
|
}
|
||||||
|
@ -217,6 +217,7 @@ namespace tunnel
|
|||||||
if (msg)
|
if (msg)
|
||||||
{
|
{
|
||||||
m_NumReceivedBytes += msg->GetLength ();
|
m_NumReceivedBytes += msg->GetLength ();
|
||||||
|
msg->from = shared_from_this ();
|
||||||
HandleI2NPMessage (msg);
|
HandleI2NPMessage (msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -390,8 +390,15 @@ namespace tunnel
|
|||||||
std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers;
|
std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers;
|
||||||
if (SelectPeers (peers, true))
|
if (SelectPeers (peers, true))
|
||||||
{
|
{
|
||||||
std::reverse (peers.begin (), peers.end ());
|
std::shared_ptr<TunnelConfig> config;
|
||||||
auto tunnel = tunnels.CreateInboundTunnel (std::make_shared<TunnelConfig> (peers), outboundTunnel);
|
if (m_NumInboundHops > 0)
|
||||||
|
{
|
||||||
|
std::reverse (peers.begin (), peers.end ());
|
||||||
|
config = std::make_shared<TunnelConfig> (peers);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
config = std::make_shared<ZeroHopsTunnelConfig> ();
|
||||||
|
auto tunnel = tunnels.CreateInboundTunnel (config, outboundTunnel);
|
||||||
tunnel->SetTunnelPool (shared_from_this ());
|
tunnel->SetTunnelPool (shared_from_this ());
|
||||||
if (tunnel->IsEstablished ()) // zero hops
|
if (tunnel->IsEstablished ()) // zero hops
|
||||||
TunnelCreated (tunnel);
|
TunnelCreated (tunnel);
|
||||||
@ -406,7 +413,9 @@ namespace tunnel
|
|||||||
if (!outboundTunnel)
|
if (!outboundTunnel)
|
||||||
outboundTunnel = tunnels.GetNextOutboundTunnel ();
|
outboundTunnel = tunnels.GetNextOutboundTunnel ();
|
||||||
LogPrint (eLogDebug, "Tunnels: Re-creating destination inbound tunnel...");
|
LogPrint (eLogDebug, "Tunnels: Re-creating destination inbound tunnel...");
|
||||||
auto newTunnel = tunnels.CreateInboundTunnel (std::make_shared<TunnelConfig>(tunnel->GetPeers ()), outboundTunnel);
|
std::shared_ptr<TunnelConfig> config = m_NumInboundHops > 0 ?
|
||||||
|
std::make_shared<TunnelConfig>(tunnel->GetPeers ()) : std::make_shared<ZeroHopsTunnelConfig> ();
|
||||||
|
auto newTunnel = tunnels.CreateInboundTunnel (config, outboundTunnel);
|
||||||
newTunnel->SetTunnelPool (shared_from_this());
|
newTunnel->SetTunnelPool (shared_from_this());
|
||||||
if (newTunnel->IsEstablished ()) // zero hops
|
if (newTunnel->IsEstablished ()) // zero hops
|
||||||
TunnelCreated (newTunnel);
|
TunnelCreated (newTunnel);
|
||||||
@ -423,8 +432,11 @@ namespace tunnel
|
|||||||
std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers;
|
std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers;
|
||||||
if (SelectPeers (peers, false))
|
if (SelectPeers (peers, false))
|
||||||
{
|
{
|
||||||
auto tunnel = tunnels.CreateOutboundTunnel (
|
std::shared_ptr<TunnelConfig> config = m_NumOutboundHops > 0 ?
|
||||||
std::make_shared<TunnelConfig> (peers, inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ()));
|
std::make_shared<TunnelConfig>(peers, inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ()) :
|
||||||
|
std::make_shared<ZeroHopsTunnelConfig> ();
|
||||||
|
|
||||||
|
auto tunnel = tunnels.CreateOutboundTunnel (config);
|
||||||
tunnel->SetTunnelPool (shared_from_this ());
|
tunnel->SetTunnelPool (shared_from_this ());
|
||||||
if (tunnel->IsEstablished ()) // zero hops
|
if (tunnel->IsEstablished ()) // zero hops
|
||||||
TunnelCreated (tunnel);
|
TunnelCreated (tunnel);
|
||||||
@ -444,9 +456,10 @@ namespace tunnel
|
|||||||
if (inboundTunnel)
|
if (inboundTunnel)
|
||||||
{
|
{
|
||||||
LogPrint (eLogDebug, "Tunnels: Re-creating destination outbound tunnel...");
|
LogPrint (eLogDebug, "Tunnels: Re-creating destination outbound tunnel...");
|
||||||
auto newTunnel = tunnels.CreateOutboundTunnel (
|
std::shared_ptr<TunnelConfig> config = m_NumOutboundHops > 0 ?
|
||||||
std::make_shared<TunnelConfig> (tunnel->GetPeers (),
|
std::make_shared<TunnelConfig>(tunnel->GetPeers (), inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ()) :
|
||||||
inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ()));
|
std::make_shared<ZeroHopsTunnelConfig> ();
|
||||||
|
auto newTunnel = tunnels.CreateOutboundTunnel (config);
|
||||||
newTunnel->SetTunnelPool (shared_from_this ());
|
newTunnel->SetTunnelPool (shared_from_this ());
|
||||||
if (newTunnel->IsEstablished ()) // zero hops
|
if (newTunnel->IsEstablished ()) // zero hops
|
||||||
TunnelCreated (newTunnel);
|
TunnelCreated (newTunnel);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user