2018-11-22 13:40:09 +07:00
|
|
|
# Nimbus
|
|
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
|
|
|
# at your option.
|
|
|
|
# This file may not be copied, modified, or distributed except according to
|
|
|
|
# those terms.
|
|
|
|
|
|
|
|
import
|
|
|
|
strutils, hexstrings, eth_p2p, options,
|
|
|
|
../db/[db_chain, state_db, storage_types],
|
2018-11-28 09:25:36 +07:00
|
|
|
json_rpc/rpcserver, json, macros, rpc_utils,
|
2018-12-03 17:54:19 +07:00
|
|
|
eth_common, ../tracer, ../vm_state, ../vm_types
|
2018-11-22 13:40:09 +07:00
|
|
|
|
|
|
|
type
|
|
|
|
TraceTxOptions = object
|
|
|
|
disableStorage: Option[bool]
|
|
|
|
disableMemory: Option[bool]
|
|
|
|
disableStack: Option[bool]
|
|
|
|
|
2018-12-03 17:54:19 +07:00
|
|
|
proc isTrue(x: Option[bool]): bool =
|
|
|
|
result = x.isSome and x.get() == true
|
|
|
|
|
|
|
|
proc setupDebugRpc*(chainDB: BaseChainDB, rpcsrv: RpcServer) =
|
2018-11-22 13:40:09 +07:00
|
|
|
|
2018-11-28 09:25:36 +07:00
|
|
|
proc getBlockBody(hash: Hash256): BlockBody =
|
2018-12-03 17:54:19 +07:00
|
|
|
if not chainDB.getBlockBody(hash, result):
|
2018-11-28 09:25:36 +07:00
|
|
|
raise newException(ValueError, "Error when retrieving block body")
|
|
|
|
|
2018-11-29 17:09:59 +00:00
|
|
|
rpcsrv.rpc("debug_traceTransaction") do(data: EthHashStr, options: Option[TraceTxOptions]) -> JsonNode:
|
2018-11-22 13:40:09 +07:00
|
|
|
## The traceTransaction debugging method will attempt to run the transaction in the exact
|
|
|
|
## same manner as it was executed on the network. It will replay any transaction that may
|
|
|
|
## have been executed prior to this one before it will finally attempt to execute the
|
|
|
|
## transaction that corresponds to the given hash.
|
|
|
|
##
|
|
|
|
## In addition to the hash of the transaction you may give it a secondary optional argument,
|
|
|
|
## which specifies the options for this specific call. The possible options are:
|
|
|
|
##
|
|
|
|
## * disableStorage: BOOL. Setting this to true will disable storage capture (default = false).
|
|
|
|
## * disableMemory: BOOL. Setting this to true will disable memory capture (default = false).
|
|
|
|
## * disableStack: BOOL. Setting this to true will disable stack capture (default = false).
|
2018-11-28 09:25:36 +07:00
|
|
|
let
|
2018-11-29 17:09:59 +00:00
|
|
|
txHash = toHash(data)
|
2018-12-03 17:54:19 +07:00
|
|
|
txDetails = chainDB.getTransactionKey(txHash)
|
|
|
|
blockHeader = chainDB.getBlockHeader(txDetails.blockNumber)
|
|
|
|
blockHash = chainDB.getBlockHash(txDetails.blockNumber)
|
2018-11-28 09:25:36 +07:00
|
|
|
blockBody = getBlockBody(blockHash)
|
2018-12-03 17:54:19 +07:00
|
|
|
|
|
|
|
var
|
|
|
|
flags: set[TracerFlags]
|
|
|
|
|
|
|
|
if options.isSome:
|
|
|
|
let opts = options.get
|
|
|
|
if opts.disableStorage.isTrue: flags.incl TracerFlags.DisableStorage
|
|
|
|
if opts.disableMemory.isTrue: flags.incl TracerFlags.DisableMemory
|
|
|
|
if opts.disableStack.isTrue: flags.incl TracerFlags.DisableStack
|
|
|
|
|
|
|
|
traceTransaction(chainDB, blockHeader, blockBody, txDetails.index, flags)
|