diff options
author | Péter Szilágyi <peterke@gmail.com> | 2017-05-30 17:54:00 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-05-30 17:54:00 +0800 |
commit | e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc (patch) | |
tree | ae915f6d81d9a5480bb84ba4d388a3b57faaa3fe | |
parent | dd06c8584368316c8fb388384b0723d8c7e543f0 (diff) | |
parent | 09d59da3a108baffb38e00212fea65c99ffc03f4 (diff) | |
download | dexon-e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc.tar dexon-e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc.tar.gz dexon-e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc.tar.bz2 dexon-e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc.tar.lz dexon-e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc.tar.xz dexon-e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc.tar.zst dexon-e96f2981e29d1893a99be20ba6a5f7ce0dcaebdc.zip |
Merge pull request #14548 from karalabe/ethstats-no-txs
ethstats: don't report transaction content, only hash
-rw-r--r-- | ethstats/ethstats.go | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/ethstats/ethstats.go b/ethstats/ethstats.go index 007347590..ad77cd1e8 100644 --- a/ethstats/ethstats.go +++ b/ethstats/ethstats.go @@ -427,21 +427,15 @@ type blockStats struct { GasLimit *big.Int `json:"gasLimit"` Diff string `json:"difficulty"` TotalDiff string `json:"totalDifficulty"` - Txs txStats `json:"transactions"` + Txs []txStats `json:"transactions"` TxHash common.Hash `json:"transactionsRoot"` Root common.Hash `json:"stateRoot"` Uncles uncleStats `json:"uncles"` } -// txStats is a custom wrapper around a transaction array to force serializing -// empty arrays instead of returning null for them. -type txStats []*types.Transaction - -func (s txStats) MarshalJSON() ([]byte, error) { - if txs := ([]*types.Transaction)(s); len(txs) > 0 { - return json.Marshal(txs) - } - return []byte("[]"), nil +// txStats is the information to report about individual transactions. +type txStats struct { + Hash common.Hash `json:"hash"` } // uncleStats is a custom wrapper around an uncle array to force serializing @@ -480,7 +474,7 @@ func (s *Service) assembleBlockStats(block *types.Block) *blockStats { var ( header *types.Header td *big.Int - txs []*types.Transaction + txs []txStats uncles []*types.Header ) if s.eth != nil { @@ -491,7 +485,10 @@ func (s *Service) assembleBlockStats(block *types.Block) *blockStats { header = block.Header() td = s.eth.BlockChain().GetTd(header.Hash(), header.Number.Uint64()) - txs = block.Transactions() + txs = make([]txStats, len(block.Transactions())) + for i, tx := range block.Transactions() { + txs[i].Hash = tx.Hash() + } uncles = block.Uncles() } else { // Light nodes would need on-demand lookups for transactions/uncles, skip @@ -501,6 +498,7 @@ func (s *Service) assembleBlockStats(block *types.Block) *blockStats { header = s.les.BlockChain().CurrentHeader() } td = s.les.BlockChain().GetTd(header.Hash(), header.Number.Uint64()) + txs = []txStats{} } // Assemble and return the block stats author, _ := s.engine.Author(header) |