# License along with this program. If not, see
# <http://www.gnu.org/licenses/agpl.html>.
-import time, sys, traceback
+import time, sys, traceback, threading
import ConfigParser
import logging
def run_rpc_command(command, stratum_tcp_port):
import socket, json
- s = socket.socket( socket.AF_INET, socket.SOCK_STREAM )
- s.connect(( host, int(stratum_tcp_port )))
+ try:
+ s = socket.socket( socket.AF_INET, socket.SOCK_STREAM )
+ s.connect(( host, int(stratum_tcp_port )))
+ except:
+ print "cannot connect to server."
+ return
+
method = 'server.' + command
request = json.dumps( { 'id':0, 'method':method, 'params':[password] } )
s.send(request + '\n')
run_rpc_command(sys.argv[1], stratum_tcp_port)
sys.exit(0)
- from processor import Dispatcher
-
+ from processor import Dispatcher, print_log
from backends.irc import ServerProcessor
+
backend_name = config.get('server', 'backend')
- try:
- backend = __import__("backends." + backend_name,
- fromlist=["BlockchainProcessor"])
- except ImportError:
- sys.stderr.write("Unknown backend '%s' specified\n" % backend_name)
- raise
+ if backend_name == 'abe':
+ from backends.abe import BlockchainProcessor
+ elif backend_name == 'libbitcoin':
+ from backends.libbitcoin import BlockchainProcessor
+ elif backend_name == 'leveldb':
+ from backends.bitcoind import BlockchainProcessor
+ else:
+ print "Unknown backend '%s' specified\n" % backend_name
+ sys.exit(1)
- print "Starting Electrum server on", host
+ for i in range(5): print ""
+ print_log( "Starting Electrum server on", host)
# Create hub
dispatcher = Dispatcher()
shared = dispatcher.shared
# Create and register processors
-
- # from backends.bitcoind import Blockchain2Processor
- # chain2_proc = Blockchain2Processor(config)
- # dispatcher.register('blockchain2', chain2_proc)
-
- chain_proc = backend.BlockchainProcessor(config)
+ chain_proc = BlockchainProcessor(config, shared)
dispatcher.register('blockchain', chain_proc)
server_proc = ServerProcessor(config)
server.start()
while not shared.stopped():
- time.sleep(1)
- print "Server stopped"
+ try:
+ time.sleep(1)
+ except:
+ shared.stop()
+
+ print_log( "Electrum Server stopped")