aboutsummaryrefslogtreecommitdiffstats
path: root/internal/ethapi/api.go
diff options
context:
space:
mode:
authorjohnliu-dexon <42129254+johnliu-dexon@users.noreply.github.com>2018-11-27 17:13:22 +0800
committerWei-Ning Huang <w@byzantine-lab.io>2019-06-12 17:27:19 +0800
commit54888db8d4e8b17d37509dbb1d8a1513cad3bd06 (patch)
tree7ae2c2bceaa3d95849c27661bae5ba34fa4a7cf3 /internal/ethapi/api.go
parent29619b5bd6c61ddf763ac7f29dd38ad30b35d459 (diff)
downloadgo-tangerine-54888db8d4e8b17d37509dbb1d8a1513cad3bd06.tar.gz
go-tangerine-54888db8d4e8b17d37509dbb1d8a1513cad3bd06.tar.zst
go-tangerine-54888db8d4e8b17d37509dbb1d8a1513cad3bd06.zip
internal/ethapi: add getBlockReceiptsByHash (#56)
* dex: add getBlockReceiptsByHash add rpc method for performance acceleration * Update internal/ethapi/api.go Co-Authored-By: johnliu-dexon <42129254+johnliu-dexon@users.noreply.github.com>
Diffstat (limited to 'internal/ethapi/api.go')
-rw-r--r--internal/ethapi/api.go35
1 files changed, 35 insertions, 0 deletions
diff --git a/internal/ethapi/api.go b/internal/ethapi/api.go
index a0b79329c..2226bebb1 100644
--- a/internal/ethapi/api.go
+++ b/internal/ethapi/api.go
@@ -673,6 +673,41 @@ func (s *PublicBlockChainAPI) GetStorageAt(ctx context.Context, address common.A
return res[:], state.Error()
}
+// GetBlockReceiptsByNumber returns the requested block receipts.
+func (s *PublicBlockChainAPI) GetBlockReceiptsByHash(ctx context.Context, blockHash common.Hash) ([]map[string]interface{}, error) {
+ receipts, err := s.b.GetReceipts(ctx, blockHash)
+ if err != nil {
+ return nil, err
+ }
+
+ resp := make([]map[string]interface{}, 0, len(receipts))
+ for _, receipt := range receipts {
+ fields := map[string]interface{}{
+ "gasUsed": hexutil.Uint64(receipt.GasUsed),
+ "cumulativeGasUsed": hexutil.Uint64(receipt.CumulativeGasUsed),
+ "contractAddress": nil,
+ "logs": receipt.Logs,
+ "logsBloom": receipt.Bloom,
+ }
+
+ // Assign receipt status or post state.
+ if len(receipt.PostState) > 0 {
+ fields["root"] = hexutil.Bytes(receipt.PostState)
+ } else {
+ fields["status"] = hexutil.Uint(receipt.Status)
+ }
+ if receipt.Logs == nil {
+ fields["logs"] = [][]*types.Log{}
+ }
+ // If the ContractAddress is 20 0x0 bytes, assume it is not a contract creation
+ if receipt.ContractAddress != (common.Address{}) {
+ fields["contractAddress"] = receipt.ContractAddress
+ }
+ resp = append(resp, fields)
+ }
+ return resp, nil
+}
+
// CallArgs represents the arguments for a call.
type CallArgs struct {
From common.Address `json:"from"`