import time
from twisted.internet import defer, protocol, reactor
-from twisted.python import log
+from twisted.python import failure, log
import p2pool
from p2pool import data as p2pool_data
self.other_version = None
self.connected2 = False
+
+ self.get_shares = deferral.GenericDeferrer(2**256, lambda id, hashes, parents, stops: self.send_sharereq(id=id, hashes=hashes, parents=parents, stops=stops))
def connectionMade(self):
p2protocol.Protocol.connectionMade(self)
('shares', pack.ListType(p2pool_data.share_type)),
])
def handle_sharereply(self, id, result, shares):
- self.node.handle_share_reply(id, result, shares, self)
+ if result == 'good':
+ res = shares
+ else:
+ res = failure.Failure("sharereply result: " + result)
+ self.get_shares.got_response(id, res)
message_bestblock = pack.ComposedType([
('header', bitcoin_data.block_header_type),
self.factory.proto_lost_connection(self, reason)
if p2pool.DEBUG:
print "Peer connection lost:", self.addr, reason
+ self.get_shares.respond_all(reason)
+
+ @defer.inlineCallbacks
+ def do_ping(self):
+ start = reactor.seconds()
+ yield self.get_shares(hashes=[0], parents=0, stops=[])
+ end = reactor.seconds()
+ defer.returnValue(end - start)
class ServerFactory(protocol.ServerFactory):
def __init__(self, node, max_conns):
def handle_get_shares(self, hashes, parents, stops, peer):
print 'handle_get_shares', (hashes, parents, stops, peer)
- def handle_share_reply(self, id, result, shares, peer):
- raise PeerMisbehavingError('sent share reply without being sent a request')
-
def handle_bestblock(self, header, peer):
print 'handle_bestblock', header
import sys
import time
-from twisted.internet import task
+from twisted.internet import defer, task
from twisted.python import log
from twisted.web import resource, static
import p2pool
from bitcoin import data as bitcoin_data
from . import data as p2pool_data
-from util import graph, math
+from util import deferred_resource, graph, math
def _atomic_read(filename):
try:
warnings=p2pool_data.get_warnings(tracker, best_share_var.value, net),
)
- class WebInterface(resource.Resource):
+ class WebInterface(deferred_resource.DeferredResource):
def __init__(self, func, mime_type='application/json', args=()):
- resource.Resource.__init__(self)
+ deferred_resource.DeferredResource.__init__(self)
self.func, self.mime_type, self.args = func, mime_type, args
def getChild(self, child, request):
return WebInterface(self.func, self.mime_type, self.args + (child,))
+ @defer.inlineCallbacks
def render_GET(self, request):
request.setHeader('Content-Type', self.mime_type)
request.setHeader('Access-Control-Allow-Origin', '*')
- res = self.func(*self.args)
- return json.dumps(res) if self.mime_type == 'application/json' else res
+ res = yield self.func(*self.args)
+ defer.returnValue(json.dumps(res) if self.mime_type == 'application/json' else res)
web_root.putChild('rate', WebInterface(lambda: p2pool_data.get_pool_attempts_per_second(tracker, best_share_var.value, 720)/(1-p2pool_data.get_average_stale_prop(tracker, best_share_var.value, 720))))
web_root.putChild('difficulty', WebInterface(lambda: bitcoin_data.target_to_difficulty(tracker.items[best_share_var.value].max_target)))
web_root.putChild('global_stats', WebInterface(get_global_stats))
web_root.putChild('local_stats', WebInterface(get_local_stats))
web_root.putChild('peer_addresses', WebInterface(lambda: ['%s:%i' % (peer.transport.getPeer().host, peer.transport.getPeer().port) for peer in p2p_node.peers.itervalues()]))
+ web_root.putChild('pings', WebInterface(defer.inlineCallbacks(lambda: defer.returnValue(
+ dict([(a, (yield b)) for a, b in
+ [(
+ '%s:%i' % (peer.transport.getPeer().host, peer.transport.getPeer().port),
+ defer.inlineCallbacks(lambda peer=peer: defer.returnValue(
+ min([(yield peer.do_ping().addCallback(lambda x: x/0.001).addErrback(lambda fail: None)) for i in xrange(3)])
+ ))()
+ ) for peer in list(p2p_node.peers.itervalues())]
+ ])
+ ))))
web_root.putChild('peer_versions', WebInterface(lambda: dict(('%s:%i' % peer.addr, peer.other_sub_version) for peer in p2p_node.peers.itervalues())))
web_root.putChild('payout_addr', WebInterface(lambda: bitcoin_data.pubkey_hash_to_address(my_pubkey_hash, net.PARENT)))
web_root.putChild('recent_blocks', WebInterface(lambda: [dict(ts=s.timestamp, hash='%064x' % s.header_hash) for s in tracker.get_chain(best_share_var.value, 24*60*60//net.SHARE_PERIOD) if s.pow_hash <= s.header['bits'].target]))