Browse Source

Merge branch 'get_mempool' into develop

master
Neil Booth 8 years ago
parent
commit
f7ceac839a
  1. 21
      server/protocol.py

21
server/protocol.py

@ -415,17 +415,20 @@ class ElectrumX(Session):
return {"block_height": height, "merkle": merkle_branch, "pos": pos} return {"block_height": height, "merkle": merkle_branch, "pos": pos}
def unconfirmed_history(self, hash168):
# Note unconfirmed history is unordered in electrum-server
# Height is -1 if unconfirmed txins, otherwise 0
mempool = self.bp.mempool_transactions(hash168)
return [{'tx_hash': tx_hash, 'height': -unconfirmed, 'fee': fee}
for tx_hash, fee, unconfirmed in mempool]
async def get_history(self, hash168): async def get_history(self, hash168):
# Note history is ordered and mempool unordered in electrum-server # Note history is ordered but unconfirmed is unordered in e-s
# For mempool, height is -1 if unconfirmed txins, otherwise 0
history = await self.async_get_history(hash168) history = await self.async_get_history(hash168)
mempool = self.bp.mempool_transactions(hash168) conf = [{'tx_hash': hash_to_str(tx_hash), 'height': height}
for tx_hash, height in history]
conf = tuple({'tx_hash': hash_to_str(tx_hash), 'height': height} return conf + self.unconfirmed_history(hash168)
for tx_hash, height in history)
unconf = tuple({'tx_hash': tx_hash, 'height': -unconfirmed, 'fee': fee}
for tx_hash, fee, unconfirmed in mempool)
return conf + unconf
def get_chunk(self, index): def get_chunk(self, index):
'''Return header chunk as hex. Index is a non-negative integer.''' '''Return header chunk as hex. Index is a non-negative integer.'''
@ -476,7 +479,7 @@ class ElectrumX(Session):
async def address_get_mempool(self, params): async def address_get_mempool(self, params):
hash168 = self.extract_hash168(params) hash168 = self.extract_hash168(params)
raise self.RPCError('get_mempool is not yet implemented') return self.unconfirmed_history(hash168)
async def address_get_proof(self, params): async def address_get_proof(self, params):
hash168 = self.extract_hash168(params) hash168 = self.extract_hash168(params)

Loading…
Cancel
Save