From 3b1f31db41d4c8bd3cdc5b4940f04503b69101b1 Mon Sep 17 00:00:00 2001 From: Ryan Schneider Date: Wed, 27 Jul 2022 11:17:57 -0700 Subject: [PATCH] eth,core: re-enable LRU cache in GetLogs --- core/blockchain_reader.go | 10 ++++++++++ eth/api_backend.go | 7 ++----- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/core/blockchain_reader.go b/core/blockchain_reader.go index 96e9f80b6aac..b6bf65bd059d 100644 --- a/core/blockchain_reader.go +++ b/core/blockchain_reader.go @@ -222,6 +222,16 @@ func (bc *BlockChain) GetReceiptsByHash(hash common.Hash) types.Receipts { return receipts } +// GetLogsByHash retrieves the logs from all receipts for all transactions in a given block. +func (bc *BlockChain) GetLogsByHash(hash common.Hash) [][]*types.Log { + receipts := bc.GetReceiptsByHash(hash) + logs := make([][]*types.Log, len(receipts)) + for i, receipt := range receipts { + logs[i] = receipt.Logs + } + return logs +} + // GetUnclesInChain retrieves all the uncles from a given block backwards until // a specific distance is reached. func (bc *BlockChain) GetUnclesInChain(block *types.Block, length int) []*types.Header { diff --git a/eth/api_backend.go b/eth/api_backend.go index 1d8ba8ea5cae..b30d8846fb8a 100644 --- a/eth/api_backend.go +++ b/eth/api_backend.go @@ -208,11 +208,8 @@ func (b *EthAPIBackend) GetLogs(ctx context.Context, hash common.Hash) ([][]*typ if number == nil { return nil, fmt.Errorf("failed to get block number for hash %#x", hash) } - logs := rawdb.ReadLogs(db, hash, *number, b.eth.blockchain.Config()) - if logs == nil { - return nil, fmt.Errorf("failed to get logs for block #%d (0x%s)", *number, hash.TerminalString()) - } - return logs, nil + + return b.eth.blockchain.GetLogsByHash(hash), nil } func (b *EthAPIBackend) GetTd(ctx context.Context, hash common.Hash) *big.Int {