From a31835c8b4086582879a4e7a48e4bdb5e4dccc3d Mon Sep 17 00:00:00 2001
From: rjl493456442 <garyrong0905@gmail.com>
Date: Sat, 26 Aug 2017 15:30:56 +0800
Subject: [PATCH] internal/ethapi: add status code to receipt rpc return
---
internal/ethapi/api.go | 17 ++++++++++++++---
1 file changed, 14 insertions(+), 3 deletions(-)
diff --git a/internal/ethapi/api.go b/internal/ethapi/api.go
index 8d1a6f746..a7cb08466 100644
--- a/internal/ethapi/api.go
+++ b/internal/ethapi/api.go
@@ -44,8 +44,10 @@ import (
)
const (
- defaultGas = 90000
- defaultGasPrice = 50 * params.Shannon
+ defaultGas = 90000
+ defaultGasPrice = 50 * params.Shannon
+ receiptStatusSuccessful = 1
+ receiptStatusFailed = 0
)
// PublicEthereumAPI provides an API to access Ethereum related information.
@@ -991,7 +993,6 @@ func (s *PublicTransactionPoolAPI) GetTransactionReceipt(hash common.Hash) (map[
from, _ := types.Sender(signer, tx)
fields := map[string]interface{}{
- "root": hexutil.Bytes(receipt.PostState),
"blockHash": blockHash,
"blockNumber": hexutil.Uint64(blockNumber),
"transactionHash": hash,
@@ -1004,6 +1005,16 @@ func (s *PublicTransactionPoolAPI) GetTransactionReceipt(hash common.Hash) (map[
"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(receiptStatusSuccessful)
+ if receipt.Failed {
+ fields["status"] = hexutil.Uint(receiptStatusFailed)
+ }
+ }
if receipt.Logs == nil {
fields["logs"] = [][]*types.Log{}
}
--
GitLab