Browse Source

check minimal router version for connected peer selection

pull/2095/head
orignal 3 months ago
parent
commit
0df895b6a7
  1. 11
      libi2pd/Transports.cpp
  2. 15
      libi2pd/Transports.h

11
libi2pd/Transports.cpp

@ -131,6 +131,17 @@ namespace transport @@ -131,6 +131,17 @@ namespace transport
LogPrint(eLogError, "Transports: Return null DHKeys");
}
void Peer::UpdateParams (std::shared_ptr<const i2p::data::RouterInfo> router)
{
if (router)
{
isHighBandwidth = router->IsHighBandwidth ();
isEligible =(bool)router->GetCompatibleTransports (true) && // reachable
router->GetCongestion () != i2p::data::RouterInfo::eRejectAll && // accepts tunnel
router->IsECIES () && router->GetVersion () >= NETDB_MIN_HIGHBANDWIDTH_VERSION; // not too old
}
}
Transports transports;
Transports::Transports ():

15
libi2pd/Transports.h

@ -79,12 +79,7 @@ namespace transport @@ -79,12 +79,7 @@ namespace transport
nextRouterInfoUpdateTime (ts + PEER_ROUTER_INFO_UPDATE_INTERVAL),
isHighBandwidth (false), isEligible (false)
{
if (router)
{
isHighBandwidth = router->IsHighBandwidth ();
isEligible = router->IsECIES () && (bool)router->GetCompatibleTransports (true) && // reachable
router->GetCongestion () != i2p::data::RouterInfo::eRejectAll;
}
UpdateParams (router);
}
void Done ()
@ -99,15 +94,11 @@ namespace transport @@ -99,15 +94,11 @@ namespace transport
void SetRouter (std::shared_ptr<const i2p::data::RouterInfo> r)
{
router = r;
if (router)
{
isHighBandwidth = router->IsHighBandwidth ();
isEligible = router->IsECIES () && (bool)router->GetCompatibleTransports (true) && // reachable
router->GetCongestion () != i2p::data::RouterInfo::eRejectAll;
}
UpdateParams (router);
}
bool IsConnected () const { return !sessions.empty (); }
void UpdateParams (std::shared_ptr<const i2p::data::RouterInfo> router);
};
const uint64_t SESSION_CREATION_TIMEOUT = 15; // in seconds

Loading…
Cancel
Save