Browse Source

get_servers

283
thomasv 13 years ago
parent
commit
a3ba122dce
  1. 26
      client/interface.py

26
client/interface.py

@ -45,7 +45,7 @@ class Interface:
return out return out
def get_servers(self): def get_servers(self):
thread.start_new_thread(self.update_servers_thread, ()) pass
def set_server(self, host, port): def set_server(self, host, port):
if host!= self.host or port!=self.port: if host!= self.host or port!=self.port:
@ -53,9 +53,6 @@ class Interface:
self.port = port self.port = port
self.is_connected = False self.is_connected = False
def update_servers_thread(self):
pass
class NativeInterface(Interface): class NativeInterface(Interface):
"""This is the original Electrum protocol. It uses polling, and a non-persistent tcp connection""" """This is the original Electrum protocol. It uses polling, and a non-persistent tcp connection"""
@ -173,6 +170,9 @@ class NativeInterface(Interface):
def start(self, wallet): def start(self, wallet):
thread.start_new_thread(self.update_wallet_thread, (wallet,)) thread.start_new_thread(self.update_wallet_thread, (wallet,))
def get_servers(self):
thread.start_new_thread(self.update_servers_thread, ())
def update_servers_thread(self): def update_servers_thread(self):
# if my server is not reachable, I should get the list from one of the default servers # if my server is not reachable, I should get the list from one of the default servers
# requesting servers could be an independent process # requesting servers could be an independent process
@ -238,15 +238,22 @@ class TCPInterface(Interface):
out = out[s+1:] out = out[s+1:]
c = json.loads(c) c = json.loads(c)
cmd = c.get('method') cmd = c.get('method')
data = c.get('result')
if cmd == 'server.banner': if cmd == 'server.banner':
self.message = c.get('result') self.message = data
self.was_updated = True
elif cmd == 'server.peers':
print "peers", data
self.servers = map( lambda x:x[1], data )
elif cmd == 'transaction.broadcast': elif cmd == 'transaction.broadcast':
self.tx_result = c.get('result') self.tx_result = data
self.tx_event.set() self.tx_event.set()
elif cmd == 'numblocks.subscribe': elif cmd == 'numblocks.subscribe':
self.blocks = c.get('result') self.blocks = data
print "num blocks",self.blocks print "num blocks",self.blocks
elif cmd =='address.subscribe': elif cmd =='address.subscribe':
@ -273,10 +280,11 @@ class TCPInterface(Interface):
traceback.print_exc(file=sys.stdout) traceback.print_exc(file=sys.stdout)
self.is_connected = False self.is_connected = False
def subscribe(self,address): def subscribe(self,address):
self.send('address.subscribe', address) self.send('address.subscribe', address)
def get_servers(self):
self.send('server.peers')
def start(self, wallet): def start(self, wallet):
thread.start_new_thread(self.listen_thread, (wallet,)) thread.start_new_thread(self.listen_thread, (wallet,))

Loading…
Cancel
Save