|
@ -34,19 +34,22 @@ try: |
|
|
f = open('/etc/electrum.conf','r') |
|
|
f = open('/etc/electrum.conf','r') |
|
|
data = f.read() |
|
|
data = f.read() |
|
|
f.close() |
|
|
f.close() |
|
|
HOST, PORT, SERVER_MESSAGE = ast.literal_eval(data) |
|
|
HOST, PORT, PASSWORD, SERVER_MESSAGE = ast.literal_eval(data) |
|
|
except: |
|
|
except: |
|
|
print "could not read /etc/electrum.conf" |
|
|
print "could not read /etc/electrum.conf" |
|
|
SERVER_MESSAGE = "Welcome to Electrum" |
|
|
SERVER_MESSAGE = "Welcome to Electrum" |
|
|
HOST = 'ecdsa.org' |
|
|
HOST = 'ecdsa.org' |
|
|
PORT = 50000 |
|
|
PORT = 50000 |
|
|
|
|
|
PASSWORD = '' |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
stopping = False |
|
|
|
|
|
|
|
|
sessions = {} |
|
|
sessions = {} |
|
|
sessions_last_time = {} |
|
|
sessions_last_time = {} |
|
|
dblock = thread.allocate_lock() |
|
|
dblock = thread.allocate_lock() |
|
|
|
|
|
|
|
|
|
|
|
peer_list = {} |
|
|
|
|
|
|
|
|
class MyStore(Datastore_class): |
|
|
class MyStore(Datastore_class): |
|
|
|
|
|
|
|
@ -278,15 +281,17 @@ def send_tx(tx): |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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) |
|
|
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) |
|
|
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) |
|
|
s.bind((HOST, PORT)) |
|
|
s.bind((HOST, PORT)) |
|
|
s.listen(1) |
|
|
s.listen(1) |
|
|
while True: |
|
|
while not stopping: |
|
|
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 |
|
@ -312,8 +317,7 @@ def client_thread(ipaddr,conn): |
|
|
out = "%d"%store.get_block_number(1) |
|
|
out = "%d"%store.get_block_number(1) |
|
|
|
|
|
|
|
|
elif cmd=='session': |
|
|
elif cmd=='session': |
|
|
import random, string |
|
|
session_id = random_string(10) |
|
|
session_id = ''.join(random.choice(string.ascii_uppercase + string.digits) for x in range(10)) |
|
|
|
|
|
try: |
|
|
try: |
|
|
addresses = ast.literal_eval(data) |
|
|
addresses = ast.literal_eval(data) |
|
|
except: |
|
|
except: |
|
@ -353,11 +357,25 @@ def client_thread(ipaddr,conn): |
|
|
out = repr(h) |
|
|
out = repr(h) |
|
|
|
|
|
|
|
|
elif cmd == 'load': |
|
|
elif cmd == 'load': |
|
|
|
|
|
if PASSWORD == data: |
|
|
out = repr( len(sessions) ) |
|
|
out = repr( len(sessions) ) |
|
|
|
|
|
else: |
|
|
|
|
|
out = 'wrong password' |
|
|
|
|
|
|
|
|
elif cmd =='tx': |
|
|
elif cmd =='tx': |
|
|
# transaction |
|
|
|
|
|
out = send_tx(data) |
|
|
out = send_tx(data) |
|
|
|
|
|
|
|
|
|
|
|
elif cmd == 'stop': |
|
|
|
|
|
global stopping |
|
|
|
|
|
if PASSWORD == data: |
|
|
|
|
|
stopping = True |
|
|
|
|
|
out = 'ok' |
|
|
|
|
|
else: |
|
|
|
|
|
out = 'wrong password' |
|
|
|
|
|
|
|
|
|
|
|
elif cmd == 'peers': |
|
|
|
|
|
out = repr(peer_list.values()) |
|
|
|
|
|
|
|
|
else: |
|
|
else: |
|
|
out = None |
|
|
out = None |
|
|
|
|
|
|
|
@ -401,7 +419,7 @@ def memorypool_update(store): |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def clean_session_thread(): |
|
|
def clean_session_thread(): |
|
|
while 1: |
|
|
while not stopping: |
|
|
time.sleep(30) |
|
|
time.sleep(30) |
|
|
t = time.time() |
|
|
t = time.time() |
|
|
for k,t0 in sessions_last_time.items(): |
|
|
for k,t0 in sessions_last_time.items(): |
|
@ -411,6 +429,42 @@ def clean_session_thread(): |
|
|
sessions_last_time.pop(k) |
|
|
sessions_last_time.pop(k) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def irc_thread(): |
|
|
|
|
|
global peer_list |
|
|
|
|
|
NICK = 'E_'+random_string(10) |
|
|
|
|
|
while not stopping: |
|
|
|
|
|
try: |
|
|
|
|
|
s = socket.socket() |
|
|
|
|
|
s.connect(('irc.freenode.net', 6667)) |
|
|
|
|
|
s.send('USER '+NICK+' '+NICK+' bla :'+NICK+'\n') |
|
|
|
|
|
s.send('NICK '+NICK+'\n') |
|
|
|
|
|
s.send('JOIN #electrum\n') |
|
|
|
|
|
t = 0 |
|
|
|
|
|
while not stopping: |
|
|
|
|
|
line = s.recv(2048) |
|
|
|
|
|
line = line.rstrip('\r\n') |
|
|
|
|
|
line = line.split() |
|
|
|
|
|
if line[0]=='PING': |
|
|
|
|
|
s.send('PONG '+line[1]+'\n') |
|
|
|
|
|
elif '353' in line: # answer to /names |
|
|
|
|
|
k = line.index('353') |
|
|
|
|
|
k2 = line.index('366') |
|
|
|
|
|
for item in line[k+1:k2]: |
|
|
|
|
|
if item[0:2] == 'E_': |
|
|
|
|
|
s.send('USERHOST %s\n'%item) |
|
|
|
|
|
elif '302' in line: # answer to /userhost |
|
|
|
|
|
k = line.index('302') |
|
|
|
|
|
name = line[k+1] |
|
|
|
|
|
host = line[k+2].split('@')[1] |
|
|
|
|
|
peer_list[name] = host |
|
|
|
|
|
elif time.time() - t > 5*60: |
|
|
|
|
|
s.send('NAMES #electrum\n') |
|
|
|
|
|
t = time.time() |
|
|
|
|
|
except: |
|
|
|
|
|
traceback.print_exc(file=sys.stdout) |
|
|
|
|
|
finally: |
|
|
|
|
|
s.close() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import traceback |
|
|
import traceback |
|
|
|
|
|
|
|
@ -418,8 +472,14 @@ import traceback |
|
|
if __name__ == '__main__': |
|
|
if __name__ == '__main__': |
|
|
|
|
|
|
|
|
if len(sys.argv)>1: |
|
|
if len(sys.argv)>1: |
|
|
request = sys.argv[1] |
|
|
cmd = sys.argv[1] |
|
|
request += "#" |
|
|
if cmd == 'load': |
|
|
|
|
|
request = "('load','%s')#"%PASSWORD |
|
|
|
|
|
elif cmd == 'peers': |
|
|
|
|
|
request = "('peers','')#" |
|
|
|
|
|
elif cmd == 'stop': |
|
|
|
|
|
request = "('stop','%s')#"%PASSWORD |
|
|
|
|
|
|
|
|
s = socket.socket( socket.AF_INET, socket.SOCK_STREAM) |
|
|
s = socket.socket( socket.AF_INET, socket.SOCK_STREAM) |
|
|
s.connect(( HOST, PORT)) |
|
|
s.connect(( HOST, PORT)) |
|
|
s.send( request ) |
|
|
s.send( request ) |
|
@ -442,8 +502,9 @@ if __name__ == '__main__': |
|
|
|
|
|
|
|
|
thread.start_new_thread(listen_thread, (store,)) |
|
|
thread.start_new_thread(listen_thread, (store,)) |
|
|
thread.start_new_thread(clean_session_thread, ()) |
|
|
thread.start_new_thread(clean_session_thread, ()) |
|
|
|
|
|
thread.start_new_thread(irc_thread, ()) |
|
|
|
|
|
|
|
|
while True: |
|
|
while not stopping: |
|
|
try: |
|
|
try: |
|
|
dblock.acquire() |
|
|
dblock.acquire() |
|
|
store.catch_up() |
|
|
store.catch_up() |
|
@ -451,6 +512,7 @@ if __name__ == '__main__': |
|
|
dblock.release() |
|
|
dblock.release() |
|
|
except: |
|
|
except: |
|
|
traceback.print_exc(file=sys.stdout) |
|
|
traceback.print_exc(file=sys.stdout) |
|
|
print "continuing..." |
|
|
|
|
|
time.sleep(10) |
|
|
time.sleep(10) |
|
|
|
|
|
|
|
|
|
|
|
print "server stopped" |
|
|
|
|
|
|
|
|