Browse Source

exclude hidden routers from tunnels

pull/73/head
orignal 11 years ago
parent
commit
b95caaf219
  1. 7
      NetDb.cpp
  2. 2
      NetDb.h
  3. 3
      RouterInfo.cpp
  4. 5
      RouterInfo.h

7
NetDb.cpp

@ -633,7 +633,7 @@ namespace data @@ -633,7 +633,7 @@ namespace data
}
}
const RouterInfo * NetDb::GetRandomRouter (const RouterInfo * compatibleWith, uint8_t caps) const
const RouterInfo * NetDb::GetRandomRouter (const RouterInfo * compatibleWith) const
{
CryptoPP::RandomNumberGenerator& rnd = i2p::context.GetRandomNumberGenerator ();
uint32_t ind = rnd.GenerateWord32 (0, m_RouterInfos.size () - 1);
@ -644,9 +644,8 @@ namespace data @@ -644,9 +644,8 @@ namespace data
{
if (i >= ind)
{
if (!it.second->IsUnreachable () &&
(!compatibleWith || it.second->IsCompatible (*compatibleWith)) &&
(!caps || (it.second->GetCaps () & caps) == caps))
if (!it.second->IsUnreachable () && !it.second->IsHidden () &&
(!compatibleWith || it.second->IsCompatible (*compatibleWith)))
return it.second;
}
else

2
NetDb.h

@ -76,7 +76,7 @@ namespace data @@ -76,7 +76,7 @@ namespace data
void HandleDatabaseStoreMsg (uint8_t * buf, size_t len);
void HandleDatabaseSearchReplyMsg (I2NPMessage * msg);
const RouterInfo * GetRandomRouter (const RouterInfo * compatibleWith = nullptr, uint8_t caps = 0) const;
const RouterInfo * GetRandomRouter (const RouterInfo * compatibleWith = nullptr) const;
void PostI2NPMsg (I2NPMessage * msg);

3
RouterInfo.cpp

@ -215,6 +215,9 @@ namespace data @@ -215,6 +215,9 @@ namespace data
case 'C':
m_Caps |= Caps::eSSUIntroducer;
break;
case 'H':
m_Caps |= Caps::eHidden;
break;
default: ;
}
cap++;

5
RouterInfo.h

@ -31,7 +31,8 @@ namespace data @@ -31,7 +31,8 @@ namespace data
eHighBandwidth = 0x02,
eReachable = 0x04,
eSSUTesting = 0x08,
eSSUIntroducer = 0x10
eSSUIntroducer = 0x10,
eHidden = 0x20
};
enum TransportStyle
@ -88,6 +89,8 @@ namespace data @@ -88,6 +89,8 @@ namespace data
bool UsesIntroducer () const;
bool IsIntroducer () const { return m_Caps & eSSUIntroducer; };
bool IsPeerTesting () const { return m_Caps & eSSUTesting; };
bool IsHidden () const { return m_Caps & eHidden; };
uint8_t GetCaps () const { return m_Caps; };
void SetUnreachable (bool unreachable) { m_IsUnreachable = unreachable; };

Loading…
Cancel
Save