commit 65e7dca3def6c90caa5a1ca7c9504c52d1892d4b
parent 2f7503c635352826a951dad70e7230bba40f2bd3
Author: ThomasV <electrumdev@gmail.com>
Date: Wed, 27 May 2015 10:42:59 +0200
Merge pull request #1249 from kyuupichan/stale_interfaces2
Common stale interface testing and switching
Diffstat:
1 file changed, 20 insertions(+), 25 deletions(-)
diff --git a/lib/network.py b/lib/network.py
@@ -114,7 +114,7 @@ def deserialize_proxy(s):
def deserialize_server(server_str):
host, port, protocol = str(server_str).split(':')
assert protocol in 'st'
- int(port)
+ int(port) # Throw if cannot be converted to int
return host, port, protocol
def serialize_server(host, port, protocol):
@@ -205,12 +205,15 @@ class Network(util.DaemonThread):
return self.heights.get(self.default_server, 0)
def server_is_lagging(self):
- h = self.get_server_height()
- if not h:
+ sh = self.get_server_height()
+ if not sh:
self.print_error('no height for main interface')
return False
- lag = self.get_local_height() - self.get_server_height()
- return lag > 1
+ lh = self.get_local_height()
+ result = (lh - sh) > 1
+ if result:
+ self.print_error('%s is lagging (%d vs %d)' % (self.default_server, sh, lh))
+ return result
def set_status(self, status):
self.connection_status = status
@@ -332,14 +335,22 @@ class Network(util.DaemonThread):
self.start_network(protocol, proxy)
elif self.default_server != server:
self.switch_to_interface(server)
- elif auto_connect and (not self.is_connected() or self.server_is_lagging()):
- self.switch_to_random_interface()
+ else:
+ self.switch_lagging_interface()
def switch_to_random_interface(self):
if self.interfaces:
server = random.choice(self.interfaces.keys())
self.switch_to_interface(server)
+ def switch_lagging_interface(self, suggestion = None):
+ '''If auto_connect and lagging, switch interface'''
+ if self.server_is_lagging() and self.auto_connect():
+ if suggestion and self.protocol == deserialize_server(suggestion)[2]:
+ self.switch_to_interface(suggestion)
+ else:
+ self.switch_to_random_interface()
+
def switch_to_interface(self, server):
'''Switch to server as our interface. If not already connected, start a
connection - we will switch on receipt of the connection notification'''
@@ -361,16 +372,6 @@ class Network(util.DaemonThread):
self.interface.stop()
self.interface = None
- def set_server(self, server):
- if self.default_server == server and self.is_connected():
- return
-
- if self.protocol != deserialize_server(server)[2]:
- return
-
- self.switch_to_interface(server)
-
-
def add_recent_server(self, i):
# list is ordered
s = i.server
@@ -381,11 +382,7 @@ class Network(util.DaemonThread):
self.save_recent_servers()
def new_blockchain_height(self, blockchain_height, i):
- if self.is_connected():
- if self.server_is_lagging():
- self.print_error("Server is lagging", blockchain_height, self.get_server_height())
- if self.auto_connect():
- self.set_server(i.server)
+ self.switch_lagging_interface(i.server)
self.notify('updated')
def process_if_notification(self, i):
@@ -526,9 +523,7 @@ class Network(util.DaemonThread):
self.blockchain.queue.put((i,result))
if i == self.interface:
- if self.server_is_lagging() and self.auto_connect():
- self.print_error("Server lagging, stopping interface")
- self.stop_interface()
+ self.switch_lagging_interface()
self.notify('updated')