Documentation ¶
Index ¶
- Constants
- func TimeoutHandler(h http.Handler, dt time.Duration, msg string) http.Handler
- type BackupChainArgs
- type BackupChainCorrectionArgs
- type BackupChainCorrectionResult
- type BackupChainResult
- type BackupSnapshotArgs
- type BackupSnapshotResult
- type BlockHashEenpPair
- type BlockHashGcpPair
- type BlockHashStakeRewardDistributionRuleSetPair
- type BlockHashVcpPair
- type BroadcastRawTransactionArgs
- type BroadcastRawTransactionAsyncArgs
- type BroadcastRawTransactionAsyncResult
- type BroadcastRawTransactionResult
- type CallSmartContractArgs
- type CallSmartContractResult
- type Callback
- type Client
- type GetAccountArgs
- type GetAccountResult
- type GetAllPendingEliteEdgeNodeStakeReturnsArgs
- type GetAllPendingEliteEdgeNodeStakeReturnsResult
- type GetBlockArgs
- type GetBlockByHeightArgs
- type GetBlockResult
- type GetBlockResultInner
- type GetBlocksByRangeArgs
- type GetBlocksResult
- type GetCodeArgs
- type GetCodeResult
- type GetEenpByHeightArgs
- type GetEenpResult
- type GetEenpStakeByHeightArgs
- type GetEenpStakeResult
- type GetEliteEdgeNodeStakeReturnsByHeightArgs
- type GetEliteEdgeNodeStakeReturnsByHeightResult
- type GetGcpByHeightArgs
- type GetGcpResult
- type GetGuardianInfoArgs
- type GetGuardianInfoResult
- type GetPeerURLsArgs
- type GetPeerURLsResult
- type GetPeersArgs
- type GetPeersResult
- type GetPendingTransactionsArgs
- type GetPendingTransactionsResult
- type GetSplitRuleArgs
- type GetSplitRuleResult
- type GetStakeRewardDistributionRuleSetByHeightArgs
- type GetStakeRewardDistributionRuleSetResult
- type GetStatusArgs
- type GetStatusResult
- type GetStorageAtArgs
- type GetStorageAtResult
- type GetTransactionArgs
- type GetTransactionResult
- type GetVcpByHeightArgs
- type GetVcpResult
- type GetVersionArgs
- type GetVersionResult
- type HTTPClient
- type HeightStakeReturnsPair
- type RPCResponse
- type ThetaRPCServer
- type ThetaRPCService
- func (t *ThetaRPCService) BackupChain(args *BackupChainArgs, result *BackupChainResult) error
- func (t *ThetaRPCService) BackupChainCorrection(args *BackupChainCorrectionArgs, result *BackupChainCorrectionResult) error
- func (t *ThetaRPCService) BackupSnapshot(args *BackupSnapshotArgs, result *BackupSnapshotResult) error
- func (t *ThetaRPCService) BroadcastRawEthTransaction(args *BroadcastRawTransactionArgs, result *BroadcastRawTransactionResult) (err error)
- func (t *ThetaRPCService) BroadcastRawEthTransactionAsync(args *BroadcastRawTransactionAsyncArgs, ...) (err error)
- func (t *ThetaRPCService) BroadcastRawTransaction(args *BroadcastRawTransactionArgs, result *BroadcastRawTransactionResult) (err error)
- func (t *ThetaRPCService) BroadcastRawTransactionAsync(args *BroadcastRawTransactionAsyncArgs, ...) (err error)
- func (t *ThetaRPCService) CallSmartContract(args *CallSmartContractArgs, result *CallSmartContractResult) (err error)
- func (t *ThetaRPCService) GetAccount(args *GetAccountArgs, result *GetAccountResult) (err error)
- func (t *ThetaRPCService) GetAllPendingEliteEdgeNodeStakeReturns(args *GetAllPendingEliteEdgeNodeStakeReturnsArgs, ...) (err error)
- func (t *ThetaRPCService) GetBlock(args *GetBlockArgs, result *GetBlockResult) (err error)
- func (t *ThetaRPCService) GetBlockByHeight(args *GetBlockByHeightArgs, result *GetBlockResult) (err error)
- func (t *ThetaRPCService) GetBlocksByRange(args *GetBlocksByRangeArgs, result *GetBlocksResult) (err error)
- func (t *ThetaRPCService) GetCode(args *GetCodeArgs, result *GetCodeResult) (err error)
- func (t *ThetaRPCService) GetEenpByHeight(args *GetEenpByHeightArgs, result *GetEenpResult) (err error)
- func (t *ThetaRPCService) GetEenpStakeByHeight(args *GetEenpStakeByHeightArgs, result *GetEenpStakeResult) (err error)
- func (t *ThetaRPCService) GetEliteEdgeNodeStakeReturnsByHeight(args *GetEliteEdgeNodeStakeReturnsByHeightArgs, ...) (err error)
- func (t *ThetaRPCService) GetGcpByHeight(args *GetGcpByHeightArgs, result *GetGcpResult) (err error)
- func (t *ThetaRPCService) GetGuardianInfo(args *GetGuardianInfoArgs, result *GetGuardianInfoResult) (err error)
- func (t *ThetaRPCService) GetPeerURLs(args *GetPeersArgs, result *GetPeerURLsResult) (err error)
- func (t *ThetaRPCService) GetPeers(args *GetPeersArgs, result *GetPeersResult) (err error)
- func (t *ThetaRPCService) GetPendingTransactions(args *GetPendingTransactionsArgs, result *GetPendingTransactionsResult) (err error)
- func (t *ThetaRPCService) GetSplitRule(args *GetSplitRuleArgs, result *GetSplitRuleResult) (err error)
- func (t *ThetaRPCService) GetStakeRewardDistributionByHeight(args *GetStakeRewardDistributionRuleSetByHeightArgs, ...) (err error)
- func (t *ThetaRPCService) GetStatus(args *GetStatusArgs, result *GetStatusResult) (err error)
- func (t *ThetaRPCService) GetStorageAt(args *GetStorageAtArgs, result *GetStorageAtResult) (err error)
- func (t *ThetaRPCService) GetTransaction(args *GetTransactionArgs, result *GetTransactionResult) (err error)
- func (t *ThetaRPCService) GetVcpByHeight(args *GetVcpByHeightArgs, result *GetVcpResult) (err error)
- func (t *ThetaRPCService) GetVersion(args *GetVersionArgs, result *GetVersionResult) (err error)
- type Tx
- type TxCallbackManager
- type TxStatus
- type TxType
- type TxWithEthHash
- type WSClient
Constants ¶
const ( TxStatusNotFound = "not_found" TxStatusPending = "pending" TxStatusFinalized = "finalized" TxStatusAbandoned = "abandoned" )
const ( TxTypeCoinbase = byte(iota) TxTypeSlash TxTypeSend TxTypeReserveFund TxTypeReleaseFund TxTypeServicePayment TxTypeSplitRule TxTypeSmartContract TxTypeDepositStake TxTypeWithdrawStake TxTypeDepositStakeTxV2 TxTypeStakeRewardDistributionTx )
Variables ¶
This section is empty.
Functions ¶
func TimeoutHandler ¶
TimeoutHandler returns a Handler that runs h with the given time limit.
The new Handler calls h.ServeHTTP to handle each request, but if a call runs for longer than its time limit, the handler responds with a 503 Service Unavailable error and the given message in its body. (If msg is empty, a suitable default message will be sent.) After such a timeout, writes by h to its ResponseWriter will return ErrHandlerTimeout.
TimeoutHandler supports the Pusher interface but does not support the Hijacker or Flusher interfaces.
Types ¶
type BackupChainArgs ¶
type BackupChainResult ¶
type BackupSnapshotArgs ¶
type BackupSnapshotResult ¶
type BackupSnapshotResult struct {
SnapshotFile string `json:"snapshot_file"`
}
type BlockHashEenpPair ¶
type BlockHashEenpPair struct { BlockHash common.Hash EENs []*core.EliteEdgeNode }
type BlockHashGcpPair ¶
type BlockHashGcpPair struct { BlockHash common.Hash Gcp *core.GuardianCandidatePool }
type BlockHashStakeRewardDistributionRuleSetPair ¶
type BlockHashStakeRewardDistributionRuleSetPair struct { BlockHash common.Hash StakeRewardDistributionRuleSet []*core.RewardDistribution }
type BlockHashVcpPair ¶
type BlockHashVcpPair struct { BlockHash common.Hash Vcp *core.ValidatorCandidatePool HeightList *types.HeightList }
type BroadcastRawTransactionArgs ¶
type BroadcastRawTransactionArgs struct {
TxBytes string `json:"tx_bytes"`
}
type BroadcastRawTransactionAsyncArgs ¶
type BroadcastRawTransactionAsyncArgs struct {
TxBytes string `json:"tx_bytes"`
}
type BroadcastRawTransactionAsyncResult ¶
type BroadcastRawTransactionAsyncResult struct {
TxHash string `json:"hash"`
}
type BroadcastRawTransactionResult ¶
type BroadcastRawTransactionResult struct { TxHash string `json:"hash"` Block *core.BlockHeader `json:"block",rlp:"nil"` }
type CallSmartContractArgs ¶
type CallSmartContractArgs struct {
SctxBytes string `json:"sctx_bytes"`
}
type CallSmartContractResult ¶
type GetAccountArgs ¶
type GetAccountArgs struct { Name string `json:"name"` Address string `json:"address"` Height common.JSONUint64 `json:"height"` Preview bool `json:"preview"` // preview the account balance from the ScreenedView }
type GetAccountResult ¶
type GetAllPendingEliteEdgeNodeStakeReturnsArgs ¶
type GetAllPendingEliteEdgeNodeStakeReturnsArgs struct { }
type GetAllPendingEliteEdgeNodeStakeReturnsResult ¶
type GetAllPendingEliteEdgeNodeStakeReturnsResult struct {
EENHeightStakeReturnsPairs []HeightStakeReturnsPair
}
type GetBlockArgs ¶
type GetBlockByHeightArgs ¶
type GetBlockByHeightArgs struct { Height common.JSONUint64 `json:"height"` IncludeEthTxHashes bool `json:"include_eth_tx_hashes"` }
type GetBlockResult ¶
type GetBlockResult struct {
*GetBlockResultInner
}
type GetBlockResultInner ¶
type GetBlockResultInner struct { ChainID string `json:"chain_id"` Epoch common.JSONUint64 `json:"epoch"` Height common.JSONUint64 `json:"height"` Parent common.Hash `json:"parent"` TxHash common.Hash `json:"transactions_hash"` StateHash common.Hash `json:"state_hash"` Timestamp *common.JSONBig `json:"timestamp"` Proposer common.Address `json:"proposer"` HCC core.CommitCertificate `json:"hcc"` GuardianVotes *core.AggregatedVotes `json:"guardian_votes"` EliteEdgeNodeVotes *core.AggregatedEENVotes `json:"elite_edge_node_votes"` Children []common.Hash `json:"children"` Status core.BlockStatus `json:"status"` Hash common.Hash `json:"hash"` Txs []interface{} `json:"transactions"` // for backward conpatibility, see function ThetaRPCService.gatherTxs() }
type GetBlocksByRangeArgs ¶
type GetBlocksByRangeArgs struct { Start common.JSONUint64 `json:"start"` End common.JSONUint64 `json:"end"` IncludeEthTxHashes bool `json:"include_eth_tx_hashes"` }
type GetBlocksResult ¶
type GetBlocksResult []*GetBlockResultInner
type GetCodeArgs ¶
type GetCodeArgs struct { Address string `json:"address"` Height common.JSONUint64 `json:"height"` }
type GetCodeResult ¶
type GetEenpByHeightArgs ¶
type GetEenpByHeightArgs struct {
Height common.JSONUint64 `json:"height"`
}
type GetEenpResult ¶
type GetEenpResult struct {
BlockHashEenpPairs []BlockHashEenpPair
}
type GetEenpStakeResult ¶
type GetEliteEdgeNodeStakeReturnsByHeightArgs ¶
type GetEliteEdgeNodeStakeReturnsByHeightArgs struct {
Height common.JSONUint64 `json:"height"`
}
type GetEliteEdgeNodeStakeReturnsByHeightResult ¶
type GetEliteEdgeNodeStakeReturnsByHeightResult struct {
EENStakeReturns []state.StakeWithHolder
}
type GetGcpByHeightArgs ¶
type GetGcpByHeightArgs struct {
Height common.JSONUint64 `json:"height"`
}
type GetGcpResult ¶
type GetGcpResult struct {
BlockHashGcpPairs []BlockHashGcpPair
}
type GetGuardianInfoArgs ¶
type GetGuardianInfoArgs struct{}
type GetGuardianInfoResult ¶
type GetPeerURLsArgs ¶
type GetPeerURLsArgs struct {
SkipEdgeNode bool `json:"skip_edge_node"`
}
type GetPeerURLsResult ¶
type GetPeerURLsResult struct {
PeerURLs []string `json:"peer_urls"`
}
type GetPeersArgs ¶
type GetPeersArgs struct {
SkipEdgeNode bool `json:"skip_edge_node"`
}
type GetPeersResult ¶
type GetPeersResult struct {
Peers []string `json:"peers"`
}
type GetPendingTransactionsArgs ¶
type GetPendingTransactionsArgs struct { }
type GetPendingTransactionsResult ¶
type GetPendingTransactionsResult struct {
TxHashes []string `json:"tx_hashes"`
}
type GetSplitRuleArgs ¶
type GetSplitRuleArgs struct {
ResourceID string `json:"resource_id"`
}
type GetSplitRuleResult ¶
type GetStakeRewardDistributionRuleSetByHeightArgs ¶
type GetStakeRewardDistributionRuleSetByHeightArgs struct { Height common.JSONUint64 `json:"height"` Address string `json:"address"` // the address of the stake holder, i.e. the guardian or elite edge node }
type GetStakeRewardDistributionRuleSetResult ¶
type GetStakeRewardDistributionRuleSetResult struct {
BlockHashStakeRewardDistributionRuleSetPairs []BlockHashStakeRewardDistributionRuleSetPair
}
type GetStatusArgs ¶
type GetStatusArgs struct{}
type GetStatusResult ¶
type GetStatusResult struct { Address string `json:"address"` ChainID string `json:"chain_id"` PeerID string `json:"peer_id"` LatestFinalizedBlockHash common.Hash `json:"latest_finalized_block_hash"` LatestFinalizedBlockHeight common.JSONUint64 `json:"latest_finalized_block_height"` LatestFinalizedBlockTime *common.JSONBig `json:"latest_finalized_block_time"` LatestFinalizedBlockEpoch common.JSONUint64 `json:"latest_finalized_block_epoch"` CurrentEpoch common.JSONUint64 `json:"current_epoch"` CurrentHeight common.JSONUint64 `json:"current_height"` CurrentTime *common.JSONBig `json:"current_time"` Syncing bool `json:"syncing"` GenesisBlockHash common.Hash `json:"genesis_block_hash"` SnapshotBlockHeight common.JSONUint64 `json:"snapshot_block_height"` SnapshotBlockHash common.Hash `json:"snapshot_block_hash"` }
type GetStorageAtArgs ¶
type GetStorageAtArgs struct { Address string `json:"address"` StoragePosition string `json:"storage_positon"` Height common.JSONUint64 `json:"height"` }
type GetStorageAtResult ¶
type GetStorageAtResult struct {
Value string `json:"value"`
}
type GetTransactionArgs ¶
type GetTransactionArgs struct {
Hash string `json:"hash"`
}
type GetTransactionResult ¶
type GetTransactionResult struct { BlockHash common.Hash `json:"block_hash"` BlockHeight common.JSONUint64 `json:"block_height"` Status TxStatus `json:"status"` TxHash common.Hash `json:"hash"` Type byte `json:"type"` Tx types.Tx `json:"transaction"` Receipt *blockchain.TxReceiptEntry `json:"receipt"` BalanceChanges *blockchain.TxBalanceChangesEntry `json:"blance_changes"` }
type GetVcpByHeightArgs ¶
type GetVcpByHeightArgs struct {
Height common.JSONUint64 `json:"height"`
}
type GetVcpResult ¶
type GetVcpResult struct {
BlockHashVcpPairs []BlockHashVcpPair
}
type GetVersionArgs ¶
type GetVersionArgs struct { }
type GetVersionResult ¶
type HTTPClient ¶
func (HTTPClient) Call ¶
func (c HTTPClient) Call(name string, args []interface{}, result interface{}) error
type HeightStakeReturnsPair ¶
type HeightStakeReturnsPair struct { HeightKey string EENStakeReturns []state.StakeWithHolder }
type RPCResponse ¶
type RPCResponse struct {
// contains filtered or unexported fields
}
func (*RPCResponse) GetObject ¶
func (r *RPCResponse) GetObject(toType interface{}) error
type ThetaRPCServer ¶
type ThetaRPCServer struct { *ThetaRPCService // contains filtered or unexported fields }
ThetaRPCServer is an instance of RPC service.
func NewThetaRPCServer ¶
func NewThetaRPCServer(mempool *mempool.Mempool, ledger *ledger.Ledger, dispatcher *dispatcher.Dispatcher, chain *blockchain.Chain, consensus *consensus.ConsensusEngine) *ThetaRPCServer
NewThetaRPCServer creates a new instance of ThetaRPCServer.
func (*ThetaRPCServer) Start ¶
func (t *ThetaRPCServer) Start(ctx context.Context)
Start creates the main goroutine.
func (*ThetaRPCServer) Stop ¶
func (t *ThetaRPCServer) Stop()
Stop notifies all goroutines to stop without blocking.
func (*ThetaRPCServer) Wait ¶
func (t *ThetaRPCServer) Wait()
Wait blocks until all goroutines stop.
type ThetaRPCService ¶
type ThetaRPCService struct {
// contains filtered or unexported fields
}
func (*ThetaRPCService) BackupChain ¶
func (t *ThetaRPCService) BackupChain(args *BackupChainArgs, result *BackupChainResult) error
func (*ThetaRPCService) BackupChainCorrection ¶
func (t *ThetaRPCService) BackupChainCorrection(args *BackupChainCorrectionArgs, result *BackupChainCorrectionResult) error
func (*ThetaRPCService) BackupSnapshot ¶
func (t *ThetaRPCService) BackupSnapshot(args *BackupSnapshotArgs, result *BackupSnapshotResult) error
func (*ThetaRPCService) BroadcastRawEthTransaction ¶
func (t *ThetaRPCService) BroadcastRawEthTransaction( args *BroadcastRawTransactionArgs, result *BroadcastRawTransactionResult) (err error)
func (*ThetaRPCService) BroadcastRawEthTransactionAsync ¶
func (t *ThetaRPCService) BroadcastRawEthTransactionAsync( args *BroadcastRawTransactionAsyncArgs, result *BroadcastRawTransactionAsyncResult) (err error)
func (*ThetaRPCService) BroadcastRawTransaction ¶
func (t *ThetaRPCService) BroadcastRawTransaction( args *BroadcastRawTransactionArgs, result *BroadcastRawTransactionResult) (err error)
func (*ThetaRPCService) BroadcastRawTransactionAsync ¶
func (t *ThetaRPCService) BroadcastRawTransactionAsync( args *BroadcastRawTransactionAsyncArgs, result *BroadcastRawTransactionAsyncResult) (err error)
func (*ThetaRPCService) CallSmartContract ¶
func (t *ThetaRPCService) CallSmartContract(args *CallSmartContractArgs, result *CallSmartContractResult) (err error)
CallSmartContract calls the smart contract. However, calling a smart contract does NOT modify the globally consensus state. It can be used for dry run, or for retrieving info from smart contracts without actually spending gas.
func (*ThetaRPCService) GetAccount ¶
func (t *ThetaRPCService) GetAccount(args *GetAccountArgs, result *GetAccountResult) (err error)
func (*ThetaRPCService) GetAllPendingEliteEdgeNodeStakeReturns ¶
func (t *ThetaRPCService) GetAllPendingEliteEdgeNodeStakeReturns( args *GetAllPendingEliteEdgeNodeStakeReturnsArgs, result *GetAllPendingEliteEdgeNodeStakeReturnsResult) (err error)
func (*ThetaRPCService) GetBlock ¶
func (t *ThetaRPCService) GetBlock(args *GetBlockArgs, result *GetBlockResult) (err error)
func (*ThetaRPCService) GetBlockByHeight ¶
func (t *ThetaRPCService) GetBlockByHeight(args *GetBlockByHeightArgs, result *GetBlockResult) (err error)
func (*ThetaRPCService) GetBlocksByRange ¶
func (t *ThetaRPCService) GetBlocksByRange(args *GetBlocksByRangeArgs, result *GetBlocksResult) (err error)
func (*ThetaRPCService) GetCode ¶
func (t *ThetaRPCService) GetCode(args *GetCodeArgs, result *GetCodeResult) (err error)
func (*ThetaRPCService) GetEenpByHeight ¶
func (t *ThetaRPCService) GetEenpByHeight(args *GetEenpByHeightArgs, result *GetEenpResult) (err error)
func (*ThetaRPCService) GetEenpStakeByHeight ¶
func (t *ThetaRPCService) GetEenpStakeByHeight(args *GetEenpStakeByHeightArgs, result *GetEenpStakeResult) (err error)
func (*ThetaRPCService) GetEliteEdgeNodeStakeReturnsByHeight ¶
func (t *ThetaRPCService) GetEliteEdgeNodeStakeReturnsByHeight( args *GetEliteEdgeNodeStakeReturnsByHeightArgs, result *GetEliteEdgeNodeStakeReturnsByHeightResult) (err error)
func (*ThetaRPCService) GetGcpByHeight ¶
func (t *ThetaRPCService) GetGcpByHeight(args *GetGcpByHeightArgs, result *GetGcpResult) (err error)
func (*ThetaRPCService) GetGuardianInfo ¶
func (t *ThetaRPCService) GetGuardianInfo(args *GetGuardianInfoArgs, result *GetGuardianInfoResult) (err error)
func (*ThetaRPCService) GetPeerURLs ¶
func (t *ThetaRPCService) GetPeerURLs(args *GetPeersArgs, result *GetPeerURLsResult) (err error)
func (*ThetaRPCService) GetPeers ¶
func (t *ThetaRPCService) GetPeers(args *GetPeersArgs, result *GetPeersResult) (err error)
func (*ThetaRPCService) GetPendingTransactions ¶
func (t *ThetaRPCService) GetPendingTransactions(args *GetPendingTransactionsArgs, result *GetPendingTransactionsResult) (err error)
func (*ThetaRPCService) GetSplitRule ¶
func (t *ThetaRPCService) GetSplitRule(args *GetSplitRuleArgs, result *GetSplitRuleResult) (err error)
func (*ThetaRPCService) GetStakeRewardDistributionByHeight ¶
func (t *ThetaRPCService) GetStakeRewardDistributionByHeight( args *GetStakeRewardDistributionRuleSetByHeightArgs, result *GetStakeRewardDistributionRuleSetResult) (err error)
func (*ThetaRPCService) GetStatus ¶
func (t *ThetaRPCService) GetStatus(args *GetStatusArgs, result *GetStatusResult) (err error)
func (*ThetaRPCService) GetStorageAt ¶
func (t *ThetaRPCService) GetStorageAt(args *GetStorageAtArgs, result *GetStorageAtResult) (err error)
func (*ThetaRPCService) GetTransaction ¶
func (t *ThetaRPCService) GetTransaction(args *GetTransactionArgs, result *GetTransactionResult) (err error)
func (*ThetaRPCService) GetVcpByHeight ¶
func (t *ThetaRPCService) GetVcpByHeight(args *GetVcpByHeightArgs, result *GetVcpResult) (err error)
func (*ThetaRPCService) GetVersion ¶
func (t *ThetaRPCService) GetVersion(args *GetVersionArgs, result *GetVersionResult) (err error)
type Tx ¶
type Tx struct { types.Tx `json:"raw"` Type byte `json:"type"` Hash common.Hash `json:"hash"` Receipt *blockchain.TxReceiptEntry `json:"receipt"` BalanceChanges *blockchain.TxBalanceChangesEntry `json:"balance_changes"` }
type TxCallbackManager ¶
type TxCallbackManager struct {
// contains filtered or unexported fields
}
func NewTxCallbackManager ¶
func NewTxCallbackManager() *TxCallbackManager
func (*TxCallbackManager) AddCallback ¶
func (m *TxCallbackManager) AddCallback(txHash common.Hash, cb func(*core.Block))
func (*TxCallbackManager) RemoveCallback ¶
func (m *TxCallbackManager) RemoveCallback(txHash common.Hash) (cb *Callback, exists bool)
func (*TxCallbackManager) Trim ¶
func (m *TxCallbackManager) Trim()
type TxWithEthHash ¶
type TxWithEthHash struct { types.Tx `json:"raw"` Type byte `json:"type"` Hash common.Hash `json:"hash"` EthTxHash common.Hash `json:"eth_tx_hash"` Receipt *blockchain.TxReceiptEntry `json:"receipt"` BalanceChanges *blockchain.TxBalanceChangesEntry `json:"balance_changes"` }