use any router for second hop of tunnel

This commit is contained in:
orignal 2014-01-24 20:53:15 -05:00
parent 9e91be671d
commit bd8ea0bac0
2 changed files with 9 additions and 7 deletions

View file

@ -499,12 +499,15 @@ namespace data
{ {
CryptoPP::RandomNumberGenerator& rnd = i2p::context.GetRandomNumberGenerator (); CryptoPP::RandomNumberGenerator& rnd = i2p::context.GetRandomNumberGenerator ();
uint32_t ind = rnd.GenerateWord32 (0, m_RouterInfos.size () - 1), i = 0; uint32_t ind = rnd.GenerateWord32 (0, m_RouterInfos.size () - 1), i = 0;
RouterInfo * last = nullptr;
for (auto it: m_RouterInfos) for (auto it: m_RouterInfos)
{ {
if (i >= ind) return it.second; if (!it.second->IsUnreachable ())
last = it.second;
if (i >= ind) break;
else i++; else i++;
} }
return nullptr; return last;
} }
void NetDb::PostI2NPMsg (I2NPMessage * msg) void NetDb::PostI2NPMsg (I2NPMessage * msg)

View file

@ -395,16 +395,15 @@ namespace tunnel
} }
else else
{ {
//OutboundTunnel * outboundTunnel = GetNextOutboundTunnel ();
LogPrint ("Creating two hops outbound tunnel..."); LogPrint ("Creating two hops outbound tunnel...");
CreateTunnel<OutboundTunnel> ( CreateTunnel<OutboundTunnel> (
new TunnelConfig (std::vector<const i2p::data::RouterInfo *> new TunnelConfig (std::vector<const i2p::data::RouterInfo *>
{ {
i2p::data::netdb.GetRandomNTCPRouter (), i2p::data::netdb.GetRandomNTCPRouter (), // first hop must be NTCP
i2p::data::netdb.GetRandomNTCPRouter () i2p::data::netdb.GetRandomRouter ()
}, },
inboundTunnel->GetTunnelConfig ())/*, inboundTunnel->GetTunnelConfig ()));
outboundTunnel*/);
} }
} }
} }