forked from premiere/premiere-libtorrent
IPv6 fix
This commit is contained in:
parent
2e93b92cb4
commit
b9d5854a99
|
@ -793,15 +793,26 @@ namespace detail
|
||||||
tcp::endpoint ep = i->sock->local_endpoint(ec);
|
tcp::endpoint ep = i->sock->local_endpoint(ec);
|
||||||
if (ec || ep.address().is_v4()) continue;
|
if (ec || ep.address().is_v4()) continue;
|
||||||
|
|
||||||
std::vector<address> const& ifs = enum_net_interfaces(m_io_service, ec);
|
if (ep.address().to_v6() != address_v6::any())
|
||||||
for (std::vector<address>::const_iterator i = ifs.begin()
|
|
||||||
, end(ifs.end()); i != end; ++i)
|
|
||||||
{
|
{
|
||||||
if (i->is_v4() || i->to_v6().is_link_local() || i->to_v6().is_loopback()) continue;
|
// if we're listening on a specific address
|
||||||
m_ipv6_interface = tcp::endpoint(*i, ep.port());
|
// pick it
|
||||||
|
m_ipv6_interface = ep;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// if we're listening on any IPv6 address, enumerate them and
|
||||||
|
// pick the first non-local address
|
||||||
|
std::vector<address> const& ifs = enum_net_interfaces(m_io_service, ec);
|
||||||
|
for (std::vector<address>::const_iterator i = ifs.begin()
|
||||||
|
, end(ifs.end()); i != end; ++i)
|
||||||
|
{
|
||||||
|
if (i->is_v4() || i->to_v6().is_link_local() || i->to_v6().is_loopback()) continue;
|
||||||
|
m_ipv6_interface = tcp::endpoint(*i, ep.port());
|
||||||
|
break;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!m_listen_sockets.empty())
|
if (!m_listen_sockets.empty())
|
||||||
|
|
Loading…
Reference in New Issue