Browse Source

version 0.44. fix jsonrpc stratum, deprecate native protocol

283
ThomasV 13 years ago
parent
commit
26b19ad6bb
  1. 122
      client/interface.py
  2. 2
      client/version.py

122
client/interface.py

@ -49,27 +49,43 @@ class Interface(threading.Thread):
#json #json
self.message_id = 0 self.message_id = 0
self.responses = Queue.Queue() self.responses = Queue.Queue()
self.methods = {}
def poke(self): def poke(self):
# push a fake response so that the getting thread exits its loop # push a fake response so that the getting thread exits its loop
self.responses.put(None) self.responses.put(None)
def queue_json_response(self, c): def queue_json_response(self, c):
#print repr(c)
#print "<--",c
msg_id = c.get('id') msg_id = c.get('id')
result = c.get('result')
error = c.get('error') error = c.get('error')
params = c.get('params',[])
method = c.get('method',None)
if not method:
return
if error: if error:
print "received error:", c, method, params print "received error:", c
return
if msg_id is not None:
method, params = self.methods.pop(msg_id)
result = c.get('result')
else: else:
# notification
method = c.get('method')
params = c.get('params')
if method == 'blockchain.numblocks.subscribe':
result = params[0]
params = []
elif method == 'blockchain.address.subscribe':
addr = params[0]
result = params[1]
params = [addr]
self.responses.put({'method':method, 'params':params, 'result':result}) self.responses.put({'method':method, 'params':params, 'result':result})
def subscribe(self, addresses): def subscribe(self, addresses):
messages = [] messages = []
for addr in addresses: for addr in addresses:
@ -148,71 +164,6 @@ class PollingInterface(Interface):
class NativeInterface(PollingInterface):
def start_session(self, addresses, version):
self.send([('session.new', [ version, addresses ])] )
self.send([('server.peers.subscribe',[])])
def poll(self):
self.send([('session.poll', [])])
def send(self, messages):
import time
cmds = {'session.new':'new_session',
'server.peers.subscribe':'peers',
'session.poll':'poll',
'blockchain.transaction.broadcast':'tx',
'blockchain.address.get_history':'h',
'blockchain.address.subscribe':'address.subscribe'
}
for m in messages:
method, params = m
cmd = cmds[method]
if cmd == 'poll':
params = self.session_id
if cmd == 'address.subscribe':
params = [ self.session_id ] + params
if cmd in ['h', 'tx']:
str_params = params[0]
elif type(params) != type(''):
str_params = repr( params )
else:
str_params = params
t1 = time.time()
request = repr ( (cmd, str_params) ) + "#"
s = socket.socket( socket.AF_INET, socket.SOCK_STREAM)
s.settimeout(DEFAULT_TIMEOUT)
s.connect(( self.host, self.port) )
s.send( request )
out = ''
while 1:
msg = s.recv(1024)
if msg: out += msg
else: break
s.close()
self.rtime = time.time() - t1
self.is_connected = True
if cmd == 'h':
out = old_to_new(out)
if cmd in ['peers','h','poll']:
out = ast.literal_eval( out )
if out == '':
out = None
if cmd == 'new_session':
self.session_id, msg = ast.literal_eval( out )
self.responses.put({'method':'server.banner', 'params':[], 'result':msg})
else:
self.responses.put({'method':method, 'params':params, 'result':out})
@ -235,6 +186,7 @@ class HttpStratumInterface(PollingInterface):
method, params = m method, params = m
if type(params) != type([]): params = [params] if type(params) != type([]): params = [params]
data.append( { 'method':method, 'id':self.message_id, 'params':params } ) data.append( { 'method':method, 'id':self.message_id, 'params':params } )
self.methods[self.message_id] = method, params
self.message_id += 1 self.message_id += 1
if data: if data:
@ -324,6 +276,8 @@ class TcpStratumInterface(Interface):
for m in messages: for m in messages:
method, params = m method, params = m
request = json.dumps( { 'id':self.message_id, 'method':method, 'params':params } ) request = json.dumps( { 'id':self.message_id, 'method':method, 'params':params } )
self.methods[self.message_id] = method, params
#print "-->",request
self.message_id += 1 self.message_id += 1
out += request + '\n' out += request + '\n'
self.s.send( out ) self.s.send( out )
@ -357,16 +311,6 @@ class WalletSynchronizer(threading.Thread):
self.wallet.banner = result self.wallet.banner = result
self.wallet.was_updated = True self.wallet.was_updated = True
elif method == 'session.poll':
# native poll
blocks, changed_addresses = result
if blocks == -1: raise BaseException("session not found")
self.wallet.blocks = int(blocks)
if changed_addresses:
self.wallet.was_updated = True
for addr, status in changed_addresses.items():
self.wallet.receive_status_callback(addr, status)
elif method == 'server.peers.subscribe': elif method == 'server.peers.subscribe':
servers = [] servers = []
for item in result: for item in result:
@ -375,18 +319,14 @@ class WalletSynchronizer(threading.Thread):
ports = [] ports = []
if len(item)>2: if len(item)>2:
for v in item[2]: for v in item[2]:
if re.match("[thn]\d+",v): if re.match("[th]\d+",v):
ports.append((v[0],v[1:])) ports.append((v[0],v[1:]))
#if not s:
# s.append(host+":50000:n")
#else:
# s.append(host+":50000:n")
if ports: if ports:
servers.append( (host, ports) ) servers.append( (host, ports) )
self.interface.servers = servers self.interface.servers = servers
elif method == 'blockchain.address.subscribe': elif method == 'blockchain.address.subscribe':
addr = params[-1] addr = params[0]
self.wallet.receive_status_callback(addr, result) self.wallet.receive_status_callback(addr, result)
elif method == 'blockchain.address.get_history': elif method == 'blockchain.address.get_history':
@ -418,15 +358,13 @@ class WalletSynchronizer(threading.Thread):
port = int(port) port = int(port)
#print protocol, host, port #print protocol, host, port
if protocol == 'n': if protocol == 't':
InterfaceClass = NativeInterface
elif protocol == 't':
InterfaceClass = TcpStratumInterface InterfaceClass = TcpStratumInterface
elif protocol == 'h': elif protocol == 'h':
InterfaceClass = HttpStratumInterface InterfaceClass = HttpStratumInterface
else: else:
print "unknown protocol" print "unknown protocol"
InterfaceClass = NativeInterface InterfaceClass = TcpStratumInterface
self.interface = InterfaceClass(host, port) self.interface = InterfaceClass(host, port)
self.wallet.interface = self.interface self.wallet.interface = self.interface

2
client/version.py

@ -1,2 +1,2 @@
ELECTRUM_VERSION = "0.43d" ELECTRUM_VERSION = "0.44"
SEED_VERSION = 4 # bump this everytime the seed generation is modified SEED_VERSION = 4 # bump this everytime the seed generation is modified

Loading…
Cancel
Save