mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-03-13 04:46:38 +01:00
Don't change Yddrasil address if router becomes unreachable through ipv6
This commit is contained in:
parent
25eae3c116
commit
bd7328345f
1 changed files with 22 additions and 13 deletions
|
@ -250,9 +250,17 @@ namespace i2p
|
||||||
bool updated = false;
|
bool updated = false;
|
||||||
for (auto& address : m_RouterInfo.GetAddresses ())
|
for (auto& address : m_RouterInfo.GetAddresses ())
|
||||||
{
|
{
|
||||||
if (address->IsNTCP2 () && (address->port != port || address->ntcp2->isPublished != publish)
|
if (address->IsNTCP2 () && (address->port != port || address->ntcp2->isPublished != publish))
|
||||||
&& ((v4 && address->IsV4 ()) || (v6 && address->IsV6 ()) ||
|
{
|
||||||
(ygg && i2p::util::net::IsYggdrasilAddress (address->host))))
|
bool isAddr = v4 && address->IsV4 ();
|
||||||
|
if (!isAddr && (v6 || ygg))
|
||||||
|
{
|
||||||
|
if (i2p::util::net::IsYggdrasilAddress (address->host))
|
||||||
|
isAddr = ygg;
|
||||||
|
else
|
||||||
|
isAddr = v6 && address->IsV6 ();
|
||||||
|
}
|
||||||
|
if (isAddr)
|
||||||
{
|
{
|
||||||
if (!port && !address->port)
|
if (!port && !address->port)
|
||||||
{
|
{
|
||||||
|
@ -267,6 +275,7 @@ namespace i2p
|
||||||
updated = true;
|
updated = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (updated)
|
if (updated)
|
||||||
UpdateRouterInfo ();
|
UpdateRouterInfo ();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue