les, light: implement ODR transaction lookup by hash (#19069)
* les, light: implement ODR transaction lookup by hash * les: delete useless file * internal/ethapi: always use backend to find transaction * les, eth, internal/ethapi: renamed GetCanonicalTransaction to GetTransaction * light: add canonical header verification to GetTransaction
This commit is contained in:
		
				
					committed by
					
						 Péter Szilágyi
						Péter Szilágyi
					
				
			
			
				
	
			
			
			
						parent
						
							f4fb1a1801
						
					
				
				
					commit
					40cdcf8c47
				
			| @@ -1155,25 +1155,32 @@ func (s *PublicTransactionPoolAPI) GetTransactionCount(ctx context.Context, addr | ||||
| } | ||||
|  | ||||
| // GetTransactionByHash returns the transaction for the given hash | ||||
| func (s *PublicTransactionPoolAPI) GetTransactionByHash(ctx context.Context, hash common.Hash) *RPCTransaction { | ||||
| func (s *PublicTransactionPoolAPI) GetTransactionByHash(ctx context.Context, hash common.Hash) (*RPCTransaction, error) { | ||||
| 	// Try to return an already finalized transaction | ||||
| 	if tx, blockHash, blockNumber, index := rawdb.ReadTransaction(s.b.ChainDb(), hash); tx != nil { | ||||
| 		return newRPCTransaction(tx, blockHash, blockNumber, index) | ||||
| 	tx, blockHash, blockNumber, index, err := s.b.GetTransaction(ctx, hash) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if tx != nil { | ||||
| 		return newRPCTransaction(tx, blockHash, blockNumber, index), nil | ||||
| 	} | ||||
| 	// No finalized transaction, try to retrieve it from the pool | ||||
| 	if tx := s.b.GetPoolTransaction(hash); tx != nil { | ||||
| 		return newRPCPendingTransaction(tx) | ||||
| 		return newRPCPendingTransaction(tx), nil | ||||
| 	} | ||||
|  | ||||
| 	// Transaction unknown, return as such | ||||
| 	return nil | ||||
| 	return nil, nil | ||||
| } | ||||
|  | ||||
| // GetRawTransactionByHash returns the bytes of the transaction for the given hash. | ||||
| func (s *PublicTransactionPoolAPI) GetRawTransactionByHash(ctx context.Context, hash common.Hash) (hexutil.Bytes, error) { | ||||
| 	var tx *types.Transaction | ||||
|  | ||||
| 	// Retrieve a finalized transaction, or a pooled otherwise | ||||
| 	if tx, _, _, _ = rawdb.ReadTransaction(s.b.ChainDb(), hash); tx == nil { | ||||
| 	tx, _, _, _, err := s.b.GetTransaction(ctx, hash) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if tx == nil { | ||||
| 		if tx = s.b.GetPoolTransaction(hash); tx == nil { | ||||
| 			// Transaction not found anywhere, abort | ||||
| 			return nil, nil | ||||
|   | ||||
		Reference in New Issue
	
	Block a user