|
@ -231,7 +231,6 @@ class Network(util.DaemonThread): |
|
|
self.banner = '' |
|
|
self.banner = '' |
|
|
self.donation_address = '' |
|
|
self.donation_address = '' |
|
|
self.relay_fee = None |
|
|
self.relay_fee = None |
|
|
self.headers = {} |
|
|
|
|
|
# callbacks passed with subscriptions |
|
|
# callbacks passed with subscriptions |
|
|
self.subscriptions = defaultdict(list) |
|
|
self.subscriptions = defaultdict(list) |
|
|
self.sub_cache = {} |
|
|
self.sub_cache = {} |
|
@ -299,8 +298,7 @@ class Network(util.DaemonThread): |
|
|
pass |
|
|
pass |
|
|
|
|
|
|
|
|
def get_server_height(self): |
|
|
def get_server_height(self): |
|
|
h = self.headers.get(self.default_server) |
|
|
return self.interface.tip if self.interface else 0 |
|
|
return h['block_height'] if h else 0 |
|
|
|
|
|
|
|
|
|
|
|
def server_is_lagging(self): |
|
|
def server_is_lagging(self): |
|
|
sh = self.get_server_height() |
|
|
sh = self.get_server_height() |
|
@ -503,7 +501,7 @@ class Network(util.DaemonThread): |
|
|
if self.server_is_lagging() and self.auto_connect: |
|
|
if self.server_is_lagging() and self.auto_connect: |
|
|
# switch to one that has the correct header (not height) |
|
|
# switch to one that has the correct header (not height) |
|
|
header = self.blockchain().read_header(self.get_local_height()) |
|
|
header = self.blockchain().read_header(self.get_local_height()) |
|
|
filtered = map(lambda x:x[0], filter(lambda x: x[1]==header, self.headers.items())) |
|
|
filtered = map(lambda x:x[0], filter(lambda x: x[1].tip_header==header, self.interfaces.items())) |
|
|
if filtered: |
|
|
if filtered: |
|
|
choice = random.choice(filtered) |
|
|
choice = random.choice(filtered) |
|
|
self.switch_to_interface(choice) |
|
|
self.switch_to_interface(choice) |
|
@ -693,7 +691,6 @@ class Network(util.DaemonThread): |
|
|
self.set_status('disconnected') |
|
|
self.set_status('disconnected') |
|
|
if server in self.interfaces: |
|
|
if server in self.interfaces: |
|
|
self.close_interface(self.interfaces[server]) |
|
|
self.close_interface(self.interfaces[server]) |
|
|
self.headers.pop(server, None) |
|
|
|
|
|
self.notify('interfaces') |
|
|
self.notify('interfaces') |
|
|
for b in self.blockchains.values(): |
|
|
for b in self.blockchains.values(): |
|
|
if b.catch_up == server: |
|
|
if b.catch_up == server: |
|
@ -707,6 +704,7 @@ class Network(util.DaemonThread): |
|
|
self.add_recent_server(server) |
|
|
self.add_recent_server(server) |
|
|
interface = Interface(server, socket) |
|
|
interface = Interface(server, socket) |
|
|
interface.blockchain = None |
|
|
interface.blockchain = None |
|
|
|
|
|
interface.tip_header = None |
|
|
interface.tip = 0 |
|
|
interface.tip = 0 |
|
|
interface.mode = 'checkpoint' |
|
|
interface.mode = 'checkpoint' |
|
|
self.interfaces[server] = interface |
|
|
self.interfaces[server] = interface |
|
@ -974,7 +972,7 @@ class Network(util.DaemonThread): |
|
|
height = header.get('block_height') |
|
|
height = header.get('block_height') |
|
|
if not height: |
|
|
if not height: |
|
|
return |
|
|
return |
|
|
self.headers[interface.server] = header |
|
|
interface.tip_header = header |
|
|
interface.tip = height |
|
|
interface.tip = height |
|
|
local_height = interface.blockchain.height() |
|
|
local_height = interface.blockchain.height() |
|
|
if interface.mode != 'default': |
|
|
if interface.mode != 'default': |
|
|