nimbus-eth1/nimbus/utils/state_dump.nim
Jacek Sieka d828dead2d
Use stateRoot/storageRoot more consistently (#2791)
* prefer the spec-derived name where possible
* don't pass stateRoot to LedgerRef and friends (it doesn't do anything)
* add deprecation warning in graphql - it needs updating to use
forkedchain instead
2024-10-27 19:56:28 +01:00

99 lines
2.5 KiB
Nim

# Nimbus
# Copyright (c) 2023-2024 Status Research & Development GmbH
# Licensed under either of
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
# http://www.apache.org/licenses/LICENSE-2.0)
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
# http://opensource.org/licenses/MIT)
# at your option. This file may not be copied, modified, or distributed except
# according to those terms.
import
std/[json, tables, strutils],
stint,
eth/common/[base, addresses, hashes],
stew/byteutils,
../db/ledger
type
DumpAccount* = ref object
balance* : UInt256
nonce* : AccountNonce
root* : Hash32
codeHash*: Hash32
code* : seq[byte]
key* : Hash32
storage* : Table[UInt256, UInt256]
StateDump* = ref object
root*: Hash32
accounts*: Table[Address, DumpAccount]
proc `%`*(x: UInt256): JsonNode =
%("0x" & x.toHex)
proc `%`*(x: seq[byte]): JsonNode =
%("0x" & x.toHex)
proc `%`*(x: Hash32): JsonNode =
%("0x" & x.data.toHex)
proc `%`*(x: AccountNonce): JsonNode =
%("0x" & x.toHex)
proc `%`*(x: Table[UInt256, UInt256]): JsonNode =
result = newJObject()
for k, v in x:
result["0x" & k.toHex] = %(v)
proc `%`*(x: DumpAccount): JsonNode =
result = %{
"balance" : %(x.balance),
"nonce" : %(x.nonce),
"root" : %(x.root),
"codeHash": %(x.codeHash),
"code" : %(x.code),
"key" : %(x.key)
}
if x.storage.len > 0:
result["storage"] = %(x.storage)
proc `%`*(x: Table[Address, DumpAccount]): JsonNode =
result = newJObject()
for k, v in x:
result["0x" & k.toHex] = %(v)
proc `%`*(x: StateDump): JsonNode =
result = %{
"root": %(x.root),
"accounts": %(x.accounts)
}
proc dumpAccount*(db: LedgerRef, acc: Address): DumpAccount =
result = DumpAccount(
balance : db.getBalance(acc),
nonce : db.getNonce(acc),
root : db.getStorageRoot(acc),
codeHash: db.getCodeHash(acc),
code : db.getCode(acc).bytes(),
key : keccak256(acc.data)
)
for k, v in db.cachedStorage(acc):
result.storage[k] = v
proc dumpAccounts*(db: LedgerRef): Table[Address, DumpAccount] =
for acc in db.addresses():
result[acc] = dumpAccount(db, acc)
proc dumpState*(db: LedgerRef): StateDump =
StateDump(
root: db.getStateRoot(),
accounts: dumpAccounts(db)
)
proc dumpAccounts*(stateDB: LedgerRef, addresses: openArray[Address]): JsonNode =
result = newJObject()
for ac in addresses:
result[ac.toHex] = %dumpAccount(stateDB, ac)