update peer ranks when our external IP changes

This commit is contained in:
Arvid Norberg 2014-01-23 03:31:36 +00:00
parent 6bda2f7430
commit 60af1aa451
5 changed files with 26 additions and 2 deletions

View File

@ -105,7 +105,8 @@ namespace libtorrent
// calculate the priority of a peer based on its address. One of the // calculate the priority of a peer based on its address. One of the
// endpoint should be our own. The priority is symmetric, so it doesn't // endpoint should be our own. The priority is symmetric, so it doesn't
// matter which is which // matter which is which
TORRENT_EXTRA_EXPORT boost::uint32_t peer_priority(tcp::endpoint e1, tcp::endpoint e2); TORRENT_EXTRA_EXPORT boost::uint32_t peer_priority(
tcp::endpoint e1, tcp::endpoint e2);
void request_a_block(torrent& t, peer_connection& c); void request_a_block(torrent& t, peer_connection& c);
@ -147,6 +148,10 @@ namespace libtorrent
void set_seed(policy::peer* p, bool s); void set_seed(policy::peer* p, bool s);
// this clears all cached peer priorities. It's called when
// our external IP changes
void clear_peer_prio();
#if TORRENT_USE_ASSERTS #if TORRENT_USE_ASSERTS
bool has_connection(const peer_connection* p); bool has_connection(const peer_connection* p);
#endif #endif

View File

@ -216,6 +216,8 @@ namespace libtorrent
void abort(); void abort();
bool is_aborted() const { return m_abort; } bool is_aborted() const { return m_abort; }
void new_external_ip();
torrent_status::state_t state() const { return (torrent_status::state_t)m_state; } torrent_status::state_t state() const { return (torrent_status::state_t)m_state; }
void set_state(torrent_status::state_t s); void set_state(torrent_status::state_t s);

View File

@ -447,6 +447,13 @@ namespace libtorrent
, m_finished(false) , m_finished(false)
{ TORRENT_ASSERT(t); } { TORRENT_ASSERT(t); }
void policy::clear_peer_prio()
{
for (peers_t::iterator i = m_peers.begin()
, end(m_peers.end()); i != end; ++i)
(*i)->peer_rank = 0;
}
// disconnects and removes all peers that are now filtered // disconnects and removes all peers that are now filtered
void policy::ip_filter_updated() void policy::ip_filter_updated()
{ {
@ -1903,7 +1910,6 @@ namespace libtorrent
// TOOD: pass in both an IPv6 and IPv4 address here // TOOD: pass in both an IPv6 and IPv4 address here
boost::uint32_t policy::peer::rank(external_ip const& external, int external_port) const boost::uint32_t policy::peer::rank(external_ip const& external, int external_port) const
{ {
//TODO 3: how do we deal with our external address changing? Pass in a force-update maybe? and keep a version number in policy
if (peer_rank == 0) if (peer_rank == 0)
peer_rank = peer_priority( peer_rank = peer_priority(
tcp::endpoint(external.external_address(this->address()), external_port) tcp::endpoint(external.external_address(this->address()), external_port)

View File

@ -6241,6 +6241,12 @@ retry:
if (m_alerts.should_post<external_ip_alert>()) if (m_alerts.should_post<external_ip_alert>())
m_alerts.post_alert(external_ip_alert(ip)); m_alerts.post_alert(external_ip_alert(ip));
for (torrent_map::iterator i = m_torrents.begin()
, end(m_torrents.end()); i != end; ++i)
{
i->second->new_external_ip();
}
// since we have a new external IP now, we need to // since we have a new external IP now, we need to
// restart the DHT with a new node ID // restart the DHT with a new node ID
#ifndef TORRENT_DISABLE_DHT #ifndef TORRENT_DISABLE_DHT

View File

@ -8594,6 +8594,11 @@ namespace libtorrent
} }
} }
void torrent::new_external_ip()
{
m_policy.clear_peer_prio();
}
void torrent::set_state(torrent_status::state_t s) void torrent::set_state(torrent_status::state_t s)
{ {
TORRENT_ASSERT(m_ses.is_network_thread()); TORRENT_ASSERT(m_ses.is_network_thread());