From f023dba3542ab03d8b0f523d6e360dbc8e603be1 Mon Sep 17 00:00:00 2001 From: beer-1 <147697694+beer-1@users.noreply.github.com> Date: Mon, 4 Nov 2024 18:28:57 +0900 Subject: [PATCH] fix jsonrpc & remove tx indexing error (#100) --- jsonrpc/backend/errors.go | 21 --------------------- jsonrpc/backend/tx.go | 27 ++++++--------------------- 2 files changed, 6 insertions(+), 42 deletions(-) diff --git a/jsonrpc/backend/errors.go b/jsonrpc/backend/errors.go index 0719c7d..28c9eb0 100644 --- a/jsonrpc/backend/errors.go +++ b/jsonrpc/backend/errors.go @@ -2,27 +2,6 @@ package backend import "errors" -// TxIndexingError is an API error that indicates the transaction indexing is not -// fully finished yet with JSON error code and a binary data blob. -type TxIndexingError struct{} - -// NewTxIndexingError creates a TxIndexingError instance. -func NewTxIndexingError() *TxIndexingError { return &TxIndexingError{} } - -// Error implement error interface, returning the error message. -func (e *TxIndexingError) Error() string { - return "transaction indexing is in progress" -} - -// ErrorCode returns the JSON error code for a revert. -// See: https://github.com/ethereum/wiki/wiki/JSON-RPC-Error-Codes-Improvement-Proposal -func (e *TxIndexingError) ErrorCode() int { - return -32000 // to be decided -} - -// ErrorData returns the hex encoded revert reason. -func (e *TxIndexingError) ErrorData() interface{} { return "transaction indexing is in progress" } - type InternalError struct { msg string } diff --git a/jsonrpc/backend/tx.go b/jsonrpc/backend/tx.go index e0dff9b..4be23ec 100644 --- a/jsonrpc/backend/tx.go +++ b/jsonrpc/backend/tx.go @@ -133,12 +133,7 @@ func (b *JSONRPCBackend) getQueryCtxWithHeight(height uint64) (context.Context, // GetTransactionByHash returns the transaction with the given hash. func (b *JSONRPCBackend) GetTransactionByHash(hash common.Hash) (*rpctypes.RPCTransaction, error) { - rpcTx, err := b.getTransaction(hash) - if rpcTx == nil { - return nil, err - } - - return rpcTx, nil + return b.getTransaction(hash) } // GetTransactionCount returns the number of transactions at the given block number. @@ -187,12 +182,10 @@ func (b *JSONRPCBackend) GetTransactionCount(address common.Address, blockNrOrHa // GetTransactionReceipt returns the transaction receipt for the given transaction hash. func (b *JSONRPCBackend) GetTransactionReceipt(hash common.Hash) (map[string]interface{}, error) { rpcTx, err := b.getTransaction(hash) - if rpcTx == nil && err == nil { + if err != nil { + return nil, err + } else if rpcTx == nil { return nil, nil // tx is not found - } else if rpcTx != nil && err != nil { - return nil, NewTxIndexingError() // tx is not fully indexed - } else if err != nil { - return nil, err // just error case } receipt, err := b.getReceipt(hash) @@ -368,14 +361,6 @@ func (b *JSONRPCBackend) GetBlockReceipts(ctx context.Context, blockNrOrHash rpc // getTransaction retrieves the lookup along with the transaction itself associate // with the given transaction hash. -// -// An error will be returned if the transaction is not found, and background -// indexing for transactions is still in progress. The error is used to indicate the -// scenario explicitly that the transaction might be reachable shortly. -// -// A null will be returned in the transaction is not found and background transaction -// indexing is already finished. The transaction is not existent from the perspective -// of node. func (b *JSONRPCBackend) getTransaction(hash common.Hash) (*rpctypes.RPCTransaction, error) { if tx, ok := b.txLookupCache.Get(hash); ok { return tx, nil @@ -385,13 +370,13 @@ func (b *JSONRPCBackend) getTransaction(hash common.Hash) (*rpctypes.RPCTransact if cacheKey, ok := b.queuedTxHashes.Load(hash); ok { if cacheItem, ok := b.queuedTxs.Get(cacheKey.(string)); ok { rpcTx := rpctypes.NewRPCTransaction(cacheItem.body, common.Hash{}, 0, 0, cacheItem.body.ChainId()) - return rpcTx, NewTxIndexingError() + return rpcTx, nil } } // check if the transaction is in the pending txs if tx := b.app.EVMIndexer().TxInMempool(hash); tx != nil { - return tx, NewTxIndexingError() + return tx, nil } queryCtx, err := b.getQueryCtx()