more command separation

This commit is contained in:
ThomasV 2011-12-23 01:57:13 +03:00
parent 3ada7b61fe
commit 928498d695

View file

@ -326,6 +326,100 @@ def send_tx(tx):
v = "error: transaction rejected by memorypool" v = "error: transaction rejected by memorypool"
return v return v
def random_string(N):
import random, string
return ''.join(random.choice(string.ascii_uppercase + string.digits) for x in range(N))
def cmd_stop(data):
global stopping
if password == data:
stopping = True
return 'ok'
else:
return 'wrong password'
def cmd_load(pw):
if password == pw:
return repr( len(sessions) )
else:
return 'wrong password'
def clear_cache(pw):
if password == pw:
store.tx_cache = {}
return 'ok'
else:
return 'wrong password'
def get_cache(pw,addr):
if password == pw:
return store.tx_cache.get(addr)
else:
return 'wrong password'
def cmd_poll(session_id):
session = sessions.get(session_id)
if session is None:
print time.asctime(), "session not found", session_id, ipaddr
out = repr( (-1, {}))
else:
t1 = time.time()
addresses = session['addresses']
session['last_time'] = time.time()
ret = {}
k = 0
for addr in addresses:
if store.tx_cache.get( addr ) is not None: k += 1
# get addtess status, i.e. the last block for that address.
tx_points = store.get_history(addr)
if not tx_points:
status = None
else:
lastpoint = tx_points[-1]
status = lastpoint['blk_hash']
# this is a temporary hack; move it up once old clients have disappeared
if status == 'mempool' and session['version'] != "old":
status = status + ':%d'% len(tx_points)
last_status = addresses.get( addr )
if last_status != status:
addresses[addr] = status
ret[addr] = status
if ret:
sessions[session_id]['addresses'] = addresses
out = repr( (block_number, ret ) )
t2 = time.time() - t1
if t2 > 10:
print "high load:", session_id, "%d/%d"%(k,len(addresses)), t2
return out
def new_session(addresses, version, ipaddr):
session_id = random_string(10)
print time.strftime("[%d/%m/%Y-%H:%M:%S]"), "new session", ipaddr, addresses[0] if addresses else addresses, len(addresses), version
sessions[session_id] = { 'addresses':{}, 'version':version, 'ip':ipaddr }
for a in addresses:
sessions[session_id]['addresses'][a] = ''
out = repr( (session_id, config.get('server','banner').replace('\\n','\n') ) )
sessions[session_id]['last_time'] = time.time()
return out
def update_session(session_id,addresses):
print time.strftime("[%d/%m/%Y-%H:%M:%S]"), "update session", ipaddr, addresses[0] if addresses else addresses, len(addresses)
sessions[session_id]['addresses'] = {}
for a in addresses:
sessions[session_id]['addresses'][a] = ''
out = 'ok'
sessions[session_id]['last_time'] = time.time()
def listen_thread(store): def listen_thread(store):
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
@ -336,9 +430,7 @@ def listen_thread(store):
conn, addr = s.accept() conn, addr = s.accept()
thread.start_new_thread(client_thread, (addr, conn,)) thread.start_new_thread(client_thread, (addr, conn,))
def random_string(N):
import random, string
return ''.join(random.choice(string.ascii_uppercase + string.digits) for x in range(N))
def client_thread(ipaddr,conn): def client_thread(ipaddr,conn):
#print "client thread", ipaddr #print "client thread", ipaddr
@ -372,42 +464,12 @@ def client_thread(ipaddr,conn):
conn.close() conn.close()
def cmd_stop(data):
global stopping
if password == data:
stopping = True
return 'ok'
else:
return 'wrong password'
def cmd_load(pw):
if password == pw:
return repr( len(sessions) )
else:
return 'wrong password'
def clear_cache(pw):
if password == pw:
store.tx_cache = {}
return 'ok'
else:
return 'wrong password'
def get_cache(pw,addr):
if password == pw:
return store.tx_cache.get(addr)
else:
return 'wrong password'
def do_command(cmd, data, ipaddr): def do_command(cmd, data, ipaddr):
if cmd=='b': if cmd=='b':
out = "%d"%block_number out = "%d"%block_number
elif cmd in ['session','new_session']: elif cmd in ['session','new_session']:
session_id = random_string(10)
try: try:
if cmd == 'session': if cmd == 'session':
addresses = ast.literal_eval(data) addresses = ast.literal_eval(data)
@ -418,14 +480,7 @@ def do_command(cmd, data, ipaddr):
except: except:
print "error", data print "error", data
return None return None
out = new_session(addresses, version, ipaddr)
print time.strftime("[%d/%m/%Y-%H:%M:%S]"), "new session", ipaddr, addresses[0] if addresses else addresses, len(addresses), version
sessions[session_id] = { 'addresses':{}, 'version':version, 'ip':ipaddr }
for a in addresses:
sessions[session_id]['addresses'][a] = ''
out = repr( (session_id, config.get('server','banner').replace('\\n','\n') ) )
sessions[session_id]['last_time'] = time.time()
elif cmd=='update_session': elif cmd=='update_session':
try: try:
@ -433,14 +488,8 @@ def do_command(cmd, data, ipaddr):
except: except:
print "error" print "error"
return None return None
out = update_session(session_id,addresses)
print time.strftime("[%d/%m/%Y-%H:%M:%S]"), "update session", ipaddr, addresses[0] if addresses else addresses, len(addresses)
sessions[session_id]['addresses'] = {}
for a in addresses:
sessions[session_id]['addresses'][a] = ''
out = 'ok'
sessions[session_id]['last_time'] = time.time()
elif cmd == 'bccapi_login': elif cmd == 'bccapi_login':
import electrum import electrum
@ -490,41 +539,7 @@ def do_command(cmd, data, ipaddr):
out = '' out = ''
elif cmd=='poll': elif cmd=='poll':
session_id = data out = cmd_poll(data)
session = sessions.get(session_id)
if session is None:
print time.asctime(), "session not found", session_id, ipaddr
out = repr( (-1, {}))
else:
t1 = time.time()
addresses = session['addresses']
session['last_time'] = time.time()
ret = {}
k = 0
for addr in addresses:
if store.tx_cache.get( addr ) is not None: k += 1
# get addtess status, i.e. the last block for that address.
tx_points = store.get_history(addr)
if not tx_points:
status = None
else:
lastpoint = tx_points[-1]
status = lastpoint['blk_hash']
# this is a temporary hack; move it up once old clients have disappeared
if status == 'mempool' and session['version'] != "old":
status = status + ':%d'% len(tx_points)
last_status = addresses.get( addr )
if last_status != status:
addresses[addr] = status
ret[addr] = status
if ret:
sessions[session_id]['addresses'] = addresses
out = repr( (block_number, ret ) )
t2 = time.time() - t1
if t2 > 10:
print "high load:", session_id, "%d/%d"%(k,len(addresses)), t2
elif cmd == 'h': elif cmd == 'h':
# history # history