From 1f815cf2d270d3ff58146f1cd64a349b1ee791f0 Mon Sep 17 00:00:00 2001 From: Jack Robison Date: Wed, 16 Feb 2022 13:41:36 -0500 Subject: [PATCH] cleanup mempool.py --- lbry/wallet/orchstr8/node.py | 2 +- lbry/wallet/server/chain_reader.py | 2 -- lbry/wallet/server/mempool.py | 52 ++++++++---------------------- 3 files changed, 15 insertions(+), 41 deletions(-) diff --git a/lbry/wallet/orchstr8/node.py b/lbry/wallet/orchstr8/node.py index 1db31e7c7..0c73dabc8 100644 --- a/lbry/wallet/orchstr8/node.py +++ b/lbry/wallet/orchstr8/node.py @@ -270,8 +270,8 @@ class SPVNode: if self.stopped: return try: - await self.es_writer.stop(delete_index=True) await self.server.stop() + await self.es_writer.stop(delete_index=True) await self.writer.stop() self.stopped = True finally: diff --git a/lbry/wallet/server/chain_reader.py b/lbry/wallet/server/chain_reader.py index 29379099b..c845766c7 100644 --- a/lbry/wallet/server/chain_reader.py +++ b/lbry/wallet/server/chain_reader.py @@ -56,8 +56,6 @@ class BlockchainReader: state = self.db.prefix_db.db_state.get() if not state or state.height <= 0: return - # if state and self.last_state and self.db.headers and self.last_state.tip == self.db.coin.header_hash(self.db.headers[-1]): - # return if self.last_state and self.last_state.height > state.height: self.log.warning("reorg detected, waiting until the writer has flushed the new blocks to advance") return diff --git a/lbry/wallet/server/mempool.py b/lbry/wallet/server/mempool.py index e7a150f83..720214361 100644 --- a/lbry/wallet/server/mempool.py +++ b/lbry/wallet/server/mempool.py @@ -66,8 +66,6 @@ class MemPool: self.raw_mempool.clear() self.raw_mempool.update(new_mempool) - # Re-sync with the new set of hashes - # hashXs = self.hashXs # hashX: [tx_hash, ...] touched_hashXs = set() @@ -82,6 +80,7 @@ class MemPool: self.touched_hashXs.pop(hashX) touched_hashXs.update(tx_hashXs) + # Re-sync with the new set of hashes tx_map = {} for tx_hash, raw_tx in self.raw_mempool.items(): if tx_hash in self.txs: @@ -95,26 +94,12 @@ class MemPool: txout_pairs = tuple((self.coin.hashX_from_script(txout.pk_script), txout.value) for txout in tx.outputs) - tx_map[tx_hash] = MemPoolTx(txin_pairs, None, txout_pairs, 0, tx_size, raw_tx) - - # Determine all prevouts not in the mempool, and fetch the - # UTXO information from the database. Failed prevout lookups - # return None - concurrent database updates happen - which is - # relied upon by _accept_transactions. Ignore prevouts that are - # generation-like. - # prevouts = tuple(prevout for tx in tx_map.values() - # for prevout in tx.prevouts - # if prevout[0] not in self.raw_mempool) - # utxos = await self._db.lookup_utxos(prevouts) - # utxo_map = dict(zip(prevouts, utxos)) - # unspent = set(utxo_map) + tx_map[tx_hash] = MemPoolTx(None, txin_pairs, txout_pairs, 0, tx_size, raw_tx) for tx_hash, tx in tx_map.items(): - in_pairs = [] - for prevout in tx.prevouts: - # utxo = utxo_map.get(prevout) - # if not utxo: - prev_hash, prev_index = prevout + prevouts = [] + # Look up the prevouts + for prev_hash, prev_index in tx.in_pairs: if prev_hash in self.txs: # accepted mempool utxo = self.txs[prev_hash].out_pairs[prev_index] elif prev_hash in tx_map: # this set of changes @@ -130,39 +115,30 @@ class MemPool: hashX = hashX_val.hashX utxo_value = prefix_db.utxo.get(hashX, prev_tx_num, prev_index) utxo = (hashX, utxo_value.amount) - # if not prev_raw: - # print("derp", prev_hash[::-1].hex()) - # print(self._db.get_tx_num(prev_hash)) - # prev_tx, prev_tx_size = self.coin.DESERIALIZER(prev_raw.raw_tx).read_tx_and_vsize() - # prev_txo = prev_tx.outputs[prev_index] - # utxo = (self.coin.hashX_from_script(prev_txo.pk_script), prev_txo.value) - in_pairs.append(utxo) + prevouts.append(utxo) - # # Spend the prevouts - # unspent.difference_update(tx.prevouts) - - # Save the in_pairs, compute the fee and accept the TX - tx.in_pairs = tuple(in_pairs) + # Save the prevouts, compute the fee and accept the TX + tx.prevouts = tuple(prevouts) # Avoid negative fees if dealing with generation-like transactions # because some in_parts would be missing - tx.fee = max(0, (sum(v for _, v in tx.in_pairs) - + tx.fee = max(0, (sum(v for _, v in tx.prevouts) - sum(v for _, v in tx.out_pairs))) self.txs[tx_hash] = tx # print(f"added {tx_hash[::-1].hex()} reader to mempool") - for hashX, value in itertools.chain(tx.in_pairs, tx.out_pairs): + for hashX, value in itertools.chain(tx.prevouts, tx.out_pairs): self.touched_hashXs[hashX].add(tx_hash) touched_hashXs.add(hashX) - # utxo_map = {prevout: utxo_map[prevout] for prevout in unspent} - return touched_hashXs def transaction_summaries(self, hashX): """Return a list of MemPoolTxSummary objects for the hashX.""" result = [] for tx_hash in self.touched_hashXs.get(hashX, ()): + if tx_hash not in self.txs: + continue # the tx hash for the touched address is an input that isn't in mempool anymore tx = self.txs[tx_hash] - has_ui = any(hash in self.txs for hash, idx in tx.prevouts) + has_ui = any(hash in self.txs for hash, idx in tx.in_pairs) result.append(MemPoolTxSummary(tx_hash, tx.fee, has_ui)) return result @@ -175,7 +151,7 @@ class MemPool: if tx_hash not in self.txs: return -2 tx = self.txs[tx_hash] - unspent_inputs = any(hash in self.raw_mempool for hash, idx in tx.prevouts) + unspent_inputs = any(hash in self.raw_mempool for hash, idx in tx.in_pairs) if unspent_inputs: return -1 return 0