Browse Source

network: ensure there is a main interface

scenario with previous code:
auto_connect enabled, there is only one server in regtest environment.
client started before server; client would not switch to server after it is started.
3.3.3.1
SomberNight 6 years ago
parent
commit
da9d1e6001
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 30
      electrum/network.py

30
electrum/network.py

@ -813,6 +813,22 @@ class Network(PrintError):
def join(self): def join(self):
self._thread.join(1) self._thread.join(1)
async def _ensure_there_is_a_main_interface(self):
if self.is_connected():
return
now = time.time()
# if auto_connect is set, try a different server
if self.auto_connect and not self.is_connecting():
await self._switch_to_random_interface()
# if auto_connect is not set, or still no main interface, retry current
if not self.is_connected() and not self.is_connecting():
if self.default_server in self.disconnected_servers:
if now - self.server_retry_time > SERVER_RETRY_INTERVAL:
self.disconnected_servers.remove(self.default_server)
self.server_retry_time = now
else:
await self.switch_to_interface(self.default_server)
async def _maintain_sessions(self): async def _maintain_sessions(self):
while True: while True:
# launch already queued up new interfaces # launch already queued up new interfaces
@ -830,18 +846,8 @@ class Network(PrintError):
self.nodes_retry_time = now self.nodes_retry_time = now
# main interface # main interface
if not self.is_connected(): await self._ensure_there_is_a_main_interface()
if self.auto_connect: if self.is_connected():
if not self.is_connecting():
await self._switch_to_random_interface()
else:
if self.default_server in self.disconnected_servers:
if now - self.server_retry_time > SERVER_RETRY_INTERVAL:
self.disconnected_servers.remove(self.default_server)
self.server_retry_time = now
else:
await self.switch_to_interface(self.default_server)
else:
if self.config.is_fee_estimates_update_required(): if self.config.is_fee_estimates_update_required():
await self.interface.group.spawn(self._request_fee_estimates, self.interface) await self.interface.group.spawn(self._request_fee_estimates, self.interface)

Loading…
Cancel
Save