mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-12 21:34:33 +00:00
Revert "Add missing pieces of EIP-7702 (#2877)"
This reverts commit b87b255398f82769d1b81d88d9005f9c29544705.
This commit is contained in:
parent
b87b255398
commit
3ee83c1715
@ -22,7 +22,7 @@ const
|
|||||||
DelegationPrefix = [0xef.byte, 0x01, 0x00]
|
DelegationPrefix = [0xef.byte, 0x01, 0x00]
|
||||||
|
|
||||||
const
|
const
|
||||||
PER_AUTH_BASE_COST* = 12500
|
PER_AUTH_BASE_COST* = 2500
|
||||||
PER_EMPTY_ACCOUNT_COST* = 25000
|
PER_EMPTY_ACCOUNT_COST* = 25000
|
||||||
|
|
||||||
func authority*(auth: Authorization): Opt[Address] =
|
func authority*(auth: Authorization): Opt[Address] =
|
||||||
|
@ -42,7 +42,6 @@ proc commitOrRollbackDependingOnGasUsed(
|
|||||||
tx: Transaction;
|
tx: Transaction;
|
||||||
gasBurned: GasInt;
|
gasBurned: GasInt;
|
||||||
priorityFee: GasInt;
|
priorityFee: GasInt;
|
||||||
blobGasUsed: GasInt;
|
|
||||||
): Result[GasInt, string] =
|
): Result[GasInt, string] =
|
||||||
# Make sure that the tx does not exceed the maximum cumulative limit as
|
# Make sure that the tx does not exceed the maximum cumulative limit as
|
||||||
# set in the block header. Again, the eip-1559 reference does not mention
|
# set in the block header. Again, the eip-1559 reference does not mention
|
||||||
@ -60,7 +59,6 @@ proc commitOrRollbackDependingOnGasUsed(
|
|||||||
# Return remaining gas to the block gas counter so it is
|
# Return remaining gas to the block gas counter so it is
|
||||||
# available for the next transaction.
|
# available for the next transaction.
|
||||||
vmState.gasPool += tx.gasLimit - gasBurned
|
vmState.gasPool += tx.gasLimit - gasBurned
|
||||||
vmState.blobGasUsed += blobGasUsed
|
|
||||||
ok(gasBurned)
|
ok(gasBurned)
|
||||||
|
|
||||||
proc processTransactionImpl(
|
proc processTransactionImpl(
|
||||||
@ -87,11 +85,11 @@ proc processTransactionImpl(
|
|||||||
|
|
||||||
vmState.gasPool -= tx.gasLimit
|
vmState.gasPool -= tx.gasLimit
|
||||||
|
|
||||||
# blobGasUsed will be added to vmState.blobGasUsed if the tx is ok.
|
|
||||||
let blobGasUsed = tx.getTotalBlobGas
|
let blobGasUsed = tx.getTotalBlobGas
|
||||||
if vmState.blobGasUsed + blobGasUsed > MAX_BLOB_GAS_PER_BLOCK:
|
if vmState.blobGasUsed + blobGasUsed > MAX_BLOB_GAS_PER_BLOCK:
|
||||||
return err("blobGasUsed " & $blobGasUsed &
|
return err("blobGasUsed " & $blobGasUsed &
|
||||||
" exceeds maximum allowance " & $MAX_BLOB_GAS_PER_BLOCK)
|
" exceeds maximum allowance " & $MAX_BLOB_GAS_PER_BLOCK)
|
||||||
|
vmState.blobGasUsed += blobGasUsed
|
||||||
|
|
||||||
# Actually, the eip-1559 reference does not mention an early exit.
|
# Actually, the eip-1559 reference does not mention an early exit.
|
||||||
#
|
#
|
||||||
@ -112,7 +110,7 @@ proc processTransactionImpl(
|
|||||||
gasBurned = tx.txCallEvm(sender, vmState, baseFee)
|
gasBurned = tx.txCallEvm(sender, vmState, baseFee)
|
||||||
vmState.captureTxEnd(tx.gasLimit - gasBurned)
|
vmState.captureTxEnd(tx.gasLimit - gasBurned)
|
||||||
|
|
||||||
commitOrRollbackDependingOnGasUsed(vmState, accTx, header, tx, gasBurned, priorityFee, blobGasUsed)
|
commitOrRollbackDependingOnGasUsed(vmState, accTx, header, tx, gasBurned, priorityFee)
|
||||||
else:
|
else:
|
||||||
err(txRes.error)
|
err(txRes.error)
|
||||||
|
|
||||||
|
@ -17,8 +17,9 @@ import
|
|||||||
../transaction/call_types,
|
../transaction/call_types,
|
||||||
../transaction,
|
../transaction,
|
||||||
../utils/utils,
|
../utils/utils,
|
||||||
"."/[dao, eip4844, eip7702, gaslimit, withdrawals],
|
"."/[dao, eip4844, gaslimit, withdrawals],
|
||||||
./pow/[difficulty, header],
|
./pow/[difficulty, header],
|
||||||
|
nimcrypto/utils as cryptoutils,
|
||||||
stew/objects,
|
stew/objects,
|
||||||
results
|
results
|
||||||
|
|
||||||
@ -341,11 +342,9 @@ proc validateTransaction*(
|
|||||||
# Clients might choose to disable this rule for RPC calls like
|
# Clients might choose to disable this rule for RPC calls like
|
||||||
# `eth_call` and `eth_estimateGas`
|
# `eth_call` and `eth_estimateGas`
|
||||||
# EOA = Externally Owned Account
|
# EOA = Externally Owned Account
|
||||||
let
|
let codeHash = roDB.getCodeHash(sender)
|
||||||
code = roDB.getCode(sender)
|
if codeHash != EMPTY_CODE_HASH:
|
||||||
delegated = code.parseDelegation()
|
return err(&"invalid tx: sender is not an EOA. sender={sender.toHex}, codeHash={codeHash.data.toHex}")
|
||||||
if code.len > 0 and not delegated:
|
|
||||||
return err(&"invalid tx: sender is not an EOA. sender={sender.toHex}, codeLen={code.len}")
|
|
||||||
|
|
||||||
if tx.txType == TxEip4844:
|
if tx.txType == TxEip4844:
|
||||||
# ensure that the user was willing to at least pay the current data gasprice
|
# ensure that the user was willing to at least pay the current data gasprice
|
||||||
|
@ -22,7 +22,8 @@ import
|
|||||||
../common/common,
|
../common/common,
|
||||||
eth/common/eth_types_rlp,
|
eth/common/eth_types_rlp,
|
||||||
chronicles, chronos,
|
chronicles, chronos,
|
||||||
sets
|
sets,
|
||||||
|
stew/assign2
|
||||||
|
|
||||||
export
|
export
|
||||||
common
|
common
|
||||||
@ -248,7 +249,8 @@ template resolveCode*(c: Computation, address: Address): CodeBytesRef =
|
|||||||
c.vmState.readOnlyStateDB.resolveCode(address)
|
c.vmState.readOnlyStateDB.resolveCode(address)
|
||||||
|
|
||||||
proc newComputation*(vmState: BaseVMState, sysCall: bool, message: Message,
|
proc newComputation*(vmState: BaseVMState, sysCall: bool, message: Message,
|
||||||
salt: ContractSalt = ZERO_CONTRACTSALT): Computation =
|
salt: ContractSalt = ZERO_CONTRACTSALT,
|
||||||
|
authorizationList: openArray[Authorization] = []): Computation =
|
||||||
new result
|
new result
|
||||||
result.vmState = vmState
|
result.vmState = vmState
|
||||||
result.msg = message
|
result.msg = message
|
||||||
@ -269,9 +271,11 @@ proc newComputation*(vmState: BaseVMState, sysCall: bool, message: Message,
|
|||||||
else:
|
else:
|
||||||
result.code = CodeStream.init(
|
result.code = CodeStream.init(
|
||||||
vmState.readOnlyStateDB.getCode(message.codeAddress))
|
vmState.readOnlyStateDB.getCode(message.codeAddress))
|
||||||
|
assign(result.authorizationList, authorizationList)
|
||||||
|
|
||||||
func newComputation*(vmState: BaseVMState, sysCall: bool,
|
func newComputation*(vmState: BaseVMState, sysCall: bool,
|
||||||
message: Message, code: CodeBytesRef): Computation =
|
message: Message, code: CodeBytesRef,
|
||||||
|
authorizationList: openArray[Authorization] = []): Computation =
|
||||||
new result
|
new result
|
||||||
result.vmState = vmState
|
result.vmState = vmState
|
||||||
result.msg = message
|
result.msg = message
|
||||||
@ -281,6 +285,7 @@ func newComputation*(vmState: BaseVMState, sysCall: bool,
|
|||||||
result.gasMeter.init(message.gas)
|
result.gasMeter.init(message.gas)
|
||||||
result.code = CodeStream.init(code)
|
result.code = CodeStream.init(code)
|
||||||
result.sysCall = sysCall
|
result.sysCall = sysCall
|
||||||
|
assign(result.authorizationList, authorizationList)
|
||||||
|
|
||||||
template gasCosts*(c: Computation): untyped =
|
template gasCosts*(c: Computation): untyped =
|
||||||
c.vmState.gasCosts
|
c.vmState.gasCosts
|
||||||
|
@ -75,20 +75,6 @@ proc gasCallEIP2929(c: Computation, address: Address): GasInt =
|
|||||||
# the form of a constant `gasCall`
|
# the form of a constant `gasCall`
|
||||||
return ColdAccountAccessCost - WarmStorageReadCost
|
return ColdAccountAccessCost - WarmStorageReadCost
|
||||||
|
|
||||||
proc delegateResolutionCost(c: Computation, address: Address): GasInt =
|
|
||||||
when evmc_enabled:
|
|
||||||
if c.host.accessAccount(address) == EVMC_ACCESS_COLD:
|
|
||||||
ColdAccountAccessCost
|
|
||||||
else:
|
|
||||||
WarmStorageReadCost
|
|
||||||
else:
|
|
||||||
c.vmState.mutateStateDB:
|
|
||||||
if not db.inAccessList(address):
|
|
||||||
db.accessList(address)
|
|
||||||
return ColdAccountAccessCost
|
|
||||||
else:
|
|
||||||
return WarmStorageReadCost
|
|
||||||
|
|
||||||
proc updateStackAndParams(q: var LocalParams; c: Computation) =
|
proc updateStackAndParams(q: var LocalParams; c: Computation) =
|
||||||
c.stack.lsTop(0)
|
c.stack.lsTop(0)
|
||||||
|
|
||||||
@ -113,7 +99,7 @@ proc updateStackAndParams(q: var LocalParams; c: Computation) =
|
|||||||
if FkPrague <= c.fork:
|
if FkPrague <= c.fork:
|
||||||
let delegateTo = parseDelegationAddress(c.getCode(q.codeAddress))
|
let delegateTo = parseDelegationAddress(c.getCode(q.codeAddress))
|
||||||
if delegateTo.isSome:
|
if delegateTo.isSome:
|
||||||
q.gasCallEIPs += delegateResolutionCost(c, delegateTo[])
|
q.gasCallEIPs += gasCallEIP2929(c, delegateTo[])
|
||||||
|
|
||||||
proc callParams(c: Computation): EvmResult[LocalParams] =
|
proc callParams(c: Computation): EvmResult[LocalParams] =
|
||||||
## Helper for callOp()
|
## Helper for callOp()
|
||||||
|
@ -9,14 +9,58 @@
|
|||||||
# according to those terms.
|
# according to those terms.
|
||||||
|
|
||||||
import
|
import
|
||||||
|
../core/eip7702,
|
||||||
../constants,
|
../constants,
|
||||||
|
../db/ledger,
|
||||||
./computation,
|
./computation,
|
||||||
./interpreter_dispatch,
|
./interpreter_dispatch,
|
||||||
|
./message,
|
||||||
./state,
|
./state,
|
||||||
./types
|
./types,
|
||||||
|
./interpreter/gas_meter
|
||||||
|
|
||||||
{.push raises: [].}
|
{.push raises: [].}
|
||||||
|
|
||||||
|
# Using `proc` as `incNonce()` might be `proc` in logging mode
|
||||||
|
proc preExecComputation(c: Computation) =
|
||||||
|
if not c.msg.isCreate:
|
||||||
|
c.vmState.mutateStateDB:
|
||||||
|
db.incNonce(c.msg.sender)
|
||||||
|
|
||||||
|
# EIP-7702
|
||||||
|
for auth in c.authorizationList:
|
||||||
|
# 1. Verify the chain id is either 0 or the chain's current ID.
|
||||||
|
if not(auth.chainId == 0.ChainId or auth.chainId == c.vmState.com.chainId):
|
||||||
|
continue
|
||||||
|
|
||||||
|
# 2. authority = ecrecover(keccak(MAGIC || rlp([chain_id, address, nonce])), y_parity, r, s]
|
||||||
|
let authority = authority(auth).valueOr:
|
||||||
|
continue
|
||||||
|
|
||||||
|
# 3. Add authority to accessed_addresses (as defined in EIP-2929.)
|
||||||
|
let ledger = c.vmState.stateDB
|
||||||
|
ledger.accessList(authority)
|
||||||
|
|
||||||
|
# 4. Verify the code of authority is either empty or already delegated.
|
||||||
|
let code = ledger.getCode(authority)
|
||||||
|
if code.len > 0:
|
||||||
|
if not parseDelegation(code):
|
||||||
|
continue
|
||||||
|
|
||||||
|
# 5. Verify the nonce of authority is equal to nonce.
|
||||||
|
if ledger.getNonce(authority) != auth.nonce:
|
||||||
|
continue
|
||||||
|
|
||||||
|
# 6. Add PER_EMPTY_ACCOUNT_COST - PER_AUTH_BASE_COST gas to the global refund counter if authority exists in the trie.
|
||||||
|
if ledger.accountExists(authority):
|
||||||
|
c.gasMeter.refundGas(PER_EMPTY_ACCOUNT_COST - PER_AUTH_BASE_COST)
|
||||||
|
|
||||||
|
# 7. Set the code of authority to be 0xef0100 || address. This is a delegation designation.
|
||||||
|
ledger.setCode(authority, @(addressToDelegation(authority)))
|
||||||
|
|
||||||
|
# 8. Increase the nonce of authority by one.
|
||||||
|
ledger.setNonce(authority, auth.nonce + 1)
|
||||||
|
|
||||||
proc postExecComputation(c: Computation) =
|
proc postExecComputation(c: Computation) =
|
||||||
if c.isSuccess:
|
if c.isSuccess:
|
||||||
if c.fork < FkLondon:
|
if c.fork < FkLondon:
|
||||||
@ -25,6 +69,7 @@ proc postExecComputation(c: Computation) =
|
|||||||
c.vmState.status = c.isSuccess
|
c.vmState.status = c.isSuccess
|
||||||
|
|
||||||
proc execComputation*(c: Computation) =
|
proc execComputation*(c: Computation) =
|
||||||
|
c.preExecComputation()
|
||||||
c.execCallOrCreate()
|
c.execCallOrCreate()
|
||||||
c.postExecComputation()
|
c.postExecComputation()
|
||||||
|
|
||||||
|
@ -93,6 +93,7 @@ type
|
|||||||
parent*, child*: Computation
|
parent*, child*: Computation
|
||||||
continuation*: proc(): EvmResultVoid {.gcsafe, raises: [].}
|
continuation*: proc(): EvmResultVoid {.gcsafe, raises: [].}
|
||||||
sysCall*: bool
|
sysCall*: bool
|
||||||
|
authorizationList*: seq[Authorization]
|
||||||
|
|
||||||
Error* = ref object
|
Error* = ref object
|
||||||
evmcStatus*: evmc_status_code
|
evmcStatus*: evmc_status_code
|
||||||
|
@ -18,7 +18,6 @@ import
|
|||||||
../db/ledger,
|
../db/ledger,
|
||||||
../common/evmforks,
|
../common/evmforks,
|
||||||
../core/eip4844,
|
../core/eip4844,
|
||||||
../core/eip7702,
|
|
||||||
./host_types,
|
./host_types,
|
||||||
./call_types
|
./call_types
|
||||||
|
|
||||||
@ -62,10 +61,6 @@ proc initialAccessListEIP2929(call: CallParams) =
|
|||||||
# access list itself, after calculating the new contract address.
|
# access list itself, after calculating the new contract address.
|
||||||
if not call.isCreate:
|
if not call.isCreate:
|
||||||
db.accessList(call.to)
|
db.accessList(call.to)
|
||||||
# If the `call.to` has a delegation, also warm its target.
|
|
||||||
let target = parseDelegationAddress(db.getCode(call.to))
|
|
||||||
if target.isSome:
|
|
||||||
db.accessList(target[])
|
|
||||||
|
|
||||||
# EIP3651 adds coinbase to the list of addresses that should start warm.
|
# EIP3651 adds coinbase to the list of addresses that should start warm.
|
||||||
if vmState.fork >= FkShanghai:
|
if vmState.fork >= FkShanghai:
|
||||||
@ -81,57 +76,6 @@ proc initialAccessListEIP2929(call: CallParams) =
|
|||||||
for key in account.storageKeys:
|
for key in account.storageKeys:
|
||||||
db.accessList(account.address, key.to(UInt256))
|
db.accessList(account.address, key.to(UInt256))
|
||||||
|
|
||||||
proc preExecComputation(vmState: BaseVMState, call: CallParams): int64 =
|
|
||||||
var gasRefund = 0
|
|
||||||
let ledger = vmState.stateDB
|
|
||||||
|
|
||||||
if not call.isCreate:
|
|
||||||
ledger.incNonce(call.sender)
|
|
||||||
|
|
||||||
# EIP-7702
|
|
||||||
for auth in call.authorizationList:
|
|
||||||
# 1. Verify the chain id is either 0 or the chain's current ID.
|
|
||||||
if not(auth.chainId == 0.ChainId or auth.chainId == vmState.com.chainId):
|
|
||||||
continue
|
|
||||||
|
|
||||||
# 2. authority = ecrecover(keccak(MAGIC || rlp([chain_id, address, nonce])), y_parity, r, s]
|
|
||||||
let authority = authority(auth).valueOr:
|
|
||||||
continue
|
|
||||||
|
|
||||||
# 3. Add authority to accessed_addresses (as defined in EIP-2929.)
|
|
||||||
ledger.accessList(authority)
|
|
||||||
|
|
||||||
# 4. Verify the code of authority is either empty or already delegated.
|
|
||||||
let code = ledger.getCode(authority)
|
|
||||||
if code.len > 0:
|
|
||||||
if not parseDelegation(code):
|
|
||||||
continue
|
|
||||||
|
|
||||||
# 5. Verify the nonce of authority is equal to nonce.
|
|
||||||
if ledger.getNonce(authority) != auth.nonce:
|
|
||||||
continue
|
|
||||||
|
|
||||||
# 6. Add PER_EMPTY_ACCOUNT_COST - PER_AUTH_BASE_COST gas to the global refund counter if authority exists in the trie.
|
|
||||||
if ledger.accountExists(authority):
|
|
||||||
gasRefund += PER_EMPTY_ACCOUNT_COST - PER_AUTH_BASE_COST
|
|
||||||
|
|
||||||
# 7. Set the code of authority to be 0xef0100 || address. This is a delegation designation.
|
|
||||||
if auth.address == default(eth_types.Address):
|
|
||||||
ledger.setCode(authority, @[])
|
|
||||||
else:
|
|
||||||
ledger.setCode(authority, @(addressToDelegation(auth.address)))
|
|
||||||
|
|
||||||
# 8. Increase the nonce of authority by one.
|
|
||||||
ledger.setNonce(authority, auth.nonce + 1)
|
|
||||||
|
|
||||||
# Usually the transaction destination and delegation target are added to
|
|
||||||
# the access list in initialAccessListEIP2929, however if the delegation is in
|
|
||||||
# the same transaction we need add here as to reduce calling slow ecrecover.
|
|
||||||
if call.to == authority:
|
|
||||||
ledger.accessList(auth.address)
|
|
||||||
|
|
||||||
gasRefund
|
|
||||||
|
|
||||||
proc setupHost(call: CallParams): TransactionHost =
|
proc setupHost(call: CallParams): TransactionHost =
|
||||||
let vmState = call.vmState
|
let vmState = call.vmState
|
||||||
vmState.txCtx = TxContext(
|
vmState.txCtx = TxContext(
|
||||||
@ -160,9 +104,6 @@ proc setupHost(call: CallParams): TransactionHost =
|
|||||||
# All other defaults in `TransactionHost` are fine.
|
# All other defaults in `TransactionHost` are fine.
|
||||||
)
|
)
|
||||||
|
|
||||||
let gasRefund = if call.sysCall: 0
|
|
||||||
else: preExecComputation(vmState, call)
|
|
||||||
|
|
||||||
# Generate new contract address, prepare code, and update message `recipient`
|
# Generate new contract address, prepare code, and update message `recipient`
|
||||||
# with the contract address. This differs from the previous Nimbus EVM API.
|
# with the contract address. This differs from the previous Nimbus EVM API.
|
||||||
# Guarded under `evmc_enabled` for now so it doesn't break vm2.
|
# Guarded under `evmc_enabled` for now so it doesn't break vm2.
|
||||||
@ -191,7 +132,9 @@ proc setupHost(call: CallParams): TransactionHost =
|
|||||||
host.msg.input_data = host.input[0].addr
|
host.msg.input_data = host.input[0].addr
|
||||||
|
|
||||||
let cMsg = hostToComputationMessage(host.msg)
|
let cMsg = hostToComputationMessage(host.msg)
|
||||||
host.computation = newComputation(vmState, call.sysCall, cMsg, code)
|
host.computation = newComputation(vmState, call.sysCall, cMsg, code,
|
||||||
|
authorizationList = call.authorizationList)
|
||||||
|
|
||||||
host.code = code
|
host.code = code
|
||||||
|
|
||||||
else:
|
else:
|
||||||
@ -203,9 +146,9 @@ proc setupHost(call: CallParams): TransactionHost =
|
|||||||
host.msg.input_data = host.input[0].addr
|
host.msg.input_data = host.input[0].addr
|
||||||
|
|
||||||
let cMsg = hostToComputationMessage(host.msg)
|
let cMsg = hostToComputationMessage(host.msg)
|
||||||
host.computation = newComputation(vmState, call.sysCall, cMsg)
|
host.computation = newComputation(vmState, call.sysCall, cMsg,
|
||||||
|
authorizationList = call.authorizationList)
|
||||||
|
|
||||||
host.computation.gasMeter.refundGas(gasRefund)
|
|
||||||
vmState.captureStart(host.computation, call.sender, call.to,
|
vmState.captureStart(host.computation, call.sender, call.to,
|
||||||
call.isCreate, call.input,
|
call.isCreate, call.input,
|
||||||
call.gasLimit, call.value)
|
call.gasLimit, call.value)
|
||||||
|
@ -14,7 +14,6 @@ import
|
|||||||
../common/evmforks,
|
../common/evmforks,
|
||||||
../evm/types,
|
../evm/types,
|
||||||
../evm/internals,
|
../evm/internals,
|
||||||
../core/eip7702,
|
|
||||||
./host_types
|
./host_types
|
||||||
|
|
||||||
type
|
type
|
||||||
@ -81,7 +80,4 @@ func intrinsicGas*(call: CallParams | Transaction, fork: EVMFork): GasInt =
|
|||||||
gas += ACCESS_LIST_ADDRESS_COST
|
gas += ACCESS_LIST_ADDRESS_COST
|
||||||
gas += GasInt(account.storageKeys.len) * ACCESS_LIST_STORAGE_KEY_COST
|
gas += GasInt(account.storageKeys.len) * ACCESS_LIST_STORAGE_KEY_COST
|
||||||
|
|
||||||
if fork >= FkPrague:
|
|
||||||
gas += call.authorizationList.len * PER_EMPTY_ACCOUNT_COST
|
|
||||||
|
|
||||||
return gas.GasInt
|
return gas.GasInt
|
||||||
|
@ -50,9 +50,6 @@ template fromJson(T: type uint64, n: JsonNode): uint64 =
|
|||||||
template fromJson(T: type EthTime, n: JsonNode): EthTime =
|
template fromJson(T: type EthTime, n: JsonNode): EthTime =
|
||||||
EthTime(fromHex[uint64](n.getStr))
|
EthTime(fromHex[uint64](n.getStr))
|
||||||
|
|
||||||
template fromJson(T: type ChainId, n: JsonNode): ChainId =
|
|
||||||
ChainId(fromHex[uint64](n.getStr))
|
|
||||||
|
|
||||||
proc fromJson(T: type PrivateKey, n: JsonNode): PrivateKey =
|
proc fromJson(T: type PrivateKey, n: JsonNode): PrivateKey =
|
||||||
var secretKey = n.getStr
|
var secretKey = n.getStr
|
||||||
removePrefix(secretKey, "0x")
|
removePrefix(secretKey, "0x")
|
||||||
@ -81,13 +78,13 @@ template required(T: type, nField: string): auto =
|
|||||||
template required(T: type, nField: string, index: int): auto =
|
template required(T: type, nField: string, index: int): auto =
|
||||||
fromJson(T, n[nField][index])
|
fromJson(T, n[nField][index])
|
||||||
|
|
||||||
template defaultZero(T: type, nField: string): auto =
|
template omitZero(T: type, nField: string): auto =
|
||||||
if n.hasKey(nField):
|
if n.hasKey(nField):
|
||||||
fromJson(T, n[nField])
|
fromJson(T, n[nField])
|
||||||
else:
|
else:
|
||||||
default(T)
|
default(T)
|
||||||
|
|
||||||
template defaultZero(T: type, nField: string, index: int): auto =
|
template omitZero(T: type, nField: string, index: int): auto =
|
||||||
if n.hasKey(nField):
|
if n.hasKey(nField):
|
||||||
fromJson(T, n[nField][index])
|
fromJson(T, n[nField][index])
|
||||||
else:
|
else:
|
||||||
@ -99,23 +96,7 @@ template optional(T: type, nField: string): auto =
|
|||||||
else:
|
else:
|
||||||
Opt.none(T)
|
Opt.none(T)
|
||||||
|
|
||||||
proc fromJson(T: type Authorization, n: JsonNode): Authorization =
|
|
||||||
Authorization(
|
|
||||||
chainId: required(ChainId, "chainId"),
|
|
||||||
address: required(Address, "address"),
|
|
||||||
nonce: required(AccountNonce, "nonce"),
|
|
||||||
v: required(uint64, "v"),
|
|
||||||
r: required(UInt256, "r"),
|
|
||||||
s: required(UInt256, "s"),
|
|
||||||
)
|
|
||||||
|
|
||||||
proc fromJson(T: type seq[Authorization], list: JsonNode): T =
|
|
||||||
for x in list:
|
|
||||||
result.add Authorization.fromJson(x)
|
|
||||||
|
|
||||||
proc txType(n: JsonNode): TxType =
|
proc txType(n: JsonNode): TxType =
|
||||||
if "authorizationList" in n:
|
|
||||||
return TxEip7702
|
|
||||||
if "blobVersionedHashes" in n:
|
if "blobVersionedHashes" in n:
|
||||||
return TxEip4844
|
return TxEip4844
|
||||||
if "gasPrice" notin n:
|
if "gasPrice" notin n:
|
||||||
@ -132,7 +113,7 @@ proc parseHeader*(n: JsonNode): Header =
|
|||||||
gasLimit : required(GasInt, "currentGasLimit"),
|
gasLimit : required(GasInt, "currentGasLimit"),
|
||||||
timestamp : required(EthTime, "currentTimestamp"),
|
timestamp : required(EthTime, "currentTimestamp"),
|
||||||
stateRoot : emptyRoot,
|
stateRoot : emptyRoot,
|
||||||
mixHash : defaultZero(Bytes32, "currentRandom"),
|
mixHash : omitZero(Bytes32, "currentRandom"),
|
||||||
baseFeePerGas : optional(UInt256, "currentBaseFee"),
|
baseFeePerGas : optional(UInt256, "currentBaseFee"),
|
||||||
withdrawalsRoot: optional(Hash32, "currentWithdrawalsRoot"),
|
withdrawalsRoot: optional(Hash32, "currentWithdrawalsRoot"),
|
||||||
excessBlobGas : optional(uint64, "currentExcessBlobGas"),
|
excessBlobGas : optional(uint64, "currentExcessBlobGas"),
|
||||||
@ -154,13 +135,12 @@ proc parseTx*(n: JsonNode, dataIndex, gasIndex, valueIndex: int): Transaction =
|
|||||||
value : required(UInt256, "value", valueIndex),
|
value : required(UInt256, "value", valueIndex),
|
||||||
payload : required(seq[byte], "data", dataIndex),
|
payload : required(seq[byte], "data", dataIndex),
|
||||||
chainId : ChainId(1),
|
chainId : ChainId(1),
|
||||||
gasPrice: defaultZero(GasInt, "gasPrice"),
|
gasPrice: omitZero(GasInt, "gasPrice"),
|
||||||
maxFeePerGas : defaultZero(GasInt, "maxFeePerGas"),
|
maxFeePerGas : omitZero(GasInt, "maxFeePerGas"),
|
||||||
accessList : defaultZero(AccessList, "accessLists", dataIndex),
|
accessList : omitZero(AccessList, "accessLists", dataIndex),
|
||||||
maxPriorityFeePerGas: defaultZero(GasInt, "maxPriorityFeePerGas"),
|
maxPriorityFeePerGas: omitZero(GasInt, "maxPriorityFeePerGas"),
|
||||||
maxFeePerBlobGas : defaultZero(UInt256, "maxFeePerBlobGas"),
|
maxFeePerBlobGas : omitZero(UInt256, "maxFeePerBlobGas"),
|
||||||
versionedHashes : defaultZero(seq[Hash32], "blobVersionedHashes"),
|
versionedHashes : omitZero(seq[Hash32], "blobVersionedHashes")
|
||||||
authorizationList : defaultZero(seq[Authorization], "authorizationList"),
|
|
||||||
)
|
)
|
||||||
|
|
||||||
let rawTo = n["to"].getStr
|
let rawTo = n["to"].getStr
|
||||||
|
@ -646,24 +646,6 @@ const
|
|||||||
output: T8nOutput(result: true),
|
output: T8nOutput(result: true),
|
||||||
expOut: "exp3.json",
|
expOut: "exp3.json",
|
||||||
),
|
),
|
||||||
TestSpec(
|
|
||||||
name: "More cancun test, plus example of rlp-transaction that cannot be decoded properly",
|
|
||||||
base: "testdata/30",
|
|
||||||
input: t8nInput(
|
|
||||||
"alloc.json", "txs_more.rlp", "env.json", "Cancun", "",
|
|
||||||
),
|
|
||||||
output: T8nOutput(alloc: true, result: true),
|
|
||||||
expOut: "exp.json",
|
|
||||||
),
|
|
||||||
TestSpec(
|
|
||||||
name: "Prague test, EIP-7702 transaction",
|
|
||||||
base: "testdata/33",
|
|
||||||
input: t8nInput(
|
|
||||||
"alloc.json", "txs.json", "env.json", "Prague", "",
|
|
||||||
),
|
|
||||||
output: T8nOutput(alloc: true, result: true),
|
|
||||||
expOut: "exp.json",
|
|
||||||
),
|
|
||||||
]
|
]
|
||||||
|
|
||||||
proc main() =
|
proc main() =
|
||||||
|
23
tools/t8n/testdata/30/alloc.json
vendored
23
tools/t8n/testdata/30/alloc.json
vendored
@ -1,23 +0,0 @@
|
|||||||
{
|
|
||||||
"0x095e7baea6a6c7c4c2dfeb977efac326af552d87" : {
|
|
||||||
"balance" : "0x0de0b6b3a7640000",
|
|
||||||
"code" : "0x60004960005500",
|
|
||||||
"nonce" : "0x00",
|
|
||||||
"storage" : {
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"0xd02d72e067e77158444ef2020ff2d325f929b363" : {
|
|
||||||
"balance": "0x01000000000000",
|
|
||||||
"code": "0x",
|
|
||||||
"nonce": "0x01",
|
|
||||||
"storage": {
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
|
|
||||||
"balance" : "0x0de0b6b3a7640000",
|
|
||||||
"code" : "0x",
|
|
||||||
"nonce" : "0x00",
|
|
||||||
"storage" : {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
23
tools/t8n/testdata/30/env.json
vendored
23
tools/t8n/testdata/30/env.json
vendored
@ -1,23 +0,0 @@
|
|||||||
{
|
|
||||||
"currentCoinbase" : "0x2adc25665018aa1fe0e6bc666dac8fc2697ff9ba",
|
|
||||||
"currentNumber" : "0x01",
|
|
||||||
"currentTimestamp" : "0x03e8",
|
|
||||||
"currentGasLimit" : "0x1000000000",
|
|
||||||
"previousHash" : "0xe4e2a30b340bec696242b67584264f878600dce98354ae0b6328740fd4ff18da",
|
|
||||||
"currentDataGasUsed" : "0x2000",
|
|
||||||
"parentTimestamp" : "0x00",
|
|
||||||
"parentDifficulty" : "0x00",
|
|
||||||
"parentUncleHash" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",
|
|
||||||
"parentBeaconBlockRoot" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",
|
|
||||||
"currentRandom" : "0x0000000000000000000000000000000000000000000000000000000000020000",
|
|
||||||
"withdrawals" : [
|
|
||||||
],
|
|
||||||
"parentBaseFee" : "0x08",
|
|
||||||
"parentGasUsed" : "0x00",
|
|
||||||
"parentGasLimit" : "0x1000000000",
|
|
||||||
"parentExcessBlobGas" : "0x1000",
|
|
||||||
"parentBlobGasUsed" : "0x2000",
|
|
||||||
"blockHashes" : {
|
|
||||||
"0" : "0xe4e2a30b340bec696242b67584264f878600dce98354ae0b6328740fd4ff18da"
|
|
||||||
}
|
|
||||||
}
|
|
64
tools/t8n/testdata/30/exp.json
vendored
64
tools/t8n/testdata/30/exp.json
vendored
@ -1,64 +0,0 @@
|
|||||||
{
|
|
||||||
"alloc": {
|
|
||||||
"0x095e7baea6a6c7c4c2dfeb977efac326af552d87": {
|
|
||||||
"code": "0x60004960005500",
|
|
||||||
"balance": "0xde0b6b3a7640000"
|
|
||||||
},
|
|
||||||
"0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b": {
|
|
||||||
"balance": "0xde0b6b3a7640000"
|
|
||||||
},
|
|
||||||
"0xd02d72e067e77158444ef2020ff2d325f929b363": {
|
|
||||||
"balance": "0xfffffffb8390",
|
|
||||||
"nonce": "0x3"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"result": {
|
|
||||||
"stateRoot": "0x3483124b6710486c9fb3e07975669c66924697c88cccdcc166af5e1218915c93",
|
|
||||||
"txRoot": "0x013509c8563d41c0ae4bf38f2d6d19fc6512a1d0d6be045079c8c9f68bf45f9d",
|
|
||||||
"receiptsRoot": "0x75308898d571eafb5cd8cde8278bf5b3d13c5f6ec074926de3bb895b519264e1",
|
|
||||||
"logsHash": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",
|
|
||||||
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"receipts": [
|
|
||||||
{
|
|
||||||
"type": "0x2",
|
|
||||||
"root": "0x",
|
|
||||||
"status": "0x1",
|
|
||||||
"cumulativeGasUsed": "0x5208",
|
|
||||||
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"logs": null,
|
|
||||||
"transactionHash": "0xa98a24882ea90916c6a86da650fbc6b14238e46f0af04a131ce92be897507476",
|
|
||||||
"contractAddress": "0x0000000000000000000000000000000000000000",
|
|
||||||
"gasUsed": "0x5208",
|
|
||||||
"effectiveGasPrice": null,
|
|
||||||
"blockHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"transactionIndex": "0x0"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "0x2",
|
|
||||||
"root": "0x",
|
|
||||||
"status": "0x1",
|
|
||||||
"cumulativeGasUsed": "0xa410",
|
|
||||||
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"logs": null,
|
|
||||||
"transactionHash": "0x36bad80acce7040c45fd32764b5c2b2d2e6f778669fb41791f73f546d56e739a",
|
|
||||||
"contractAddress": "0x0000000000000000000000000000000000000000",
|
|
||||||
"gasUsed": "0x5208",
|
|
||||||
"effectiveGasPrice": null,
|
|
||||||
"blockHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"transactionIndex": "0x2"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"rejected": [
|
|
||||||
{
|
|
||||||
"index": 1,
|
|
||||||
"error": "rlp: input string too short for common.Address, decoding into (types.Transaction)(types.BlobTx).To"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"currentDifficulty": null,
|
|
||||||
"gasUsed": "0xa410",
|
|
||||||
"currentBaseFee": "0x7",
|
|
||||||
"withdrawalsRoot": "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
|
|
||||||
"currentExcessBlobGas": "0x0",
|
|
||||||
"blobGasUsed": "0x0"
|
|
||||||
}
|
|
||||||
}
|
|
1
tools/t8n/testdata/30/txs_more.rlp
vendored
1
tools/t8n/testdata/30/txs_more.rlp
vendored
@ -1 +0,0 @@
|
|||||||
"0xf901adb86702f864010180820fa08284d09411111111111111111111111111111111111111118080c001a0b7dfab36232379bb3d1497a4f91c1966b1f932eae3ade107bf5d723b9cb474e0a06261c359a10f2132f126d250485b90cf20f30340801244a08ef6142ab33d1904b8d903f8d601800285012a05f200833d090080830186a000f85bf85994095e7baea6a6c7c4c2dfeb977efac326af552d87f842a00000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000010ae1a001a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d880a0fc12b67159a3567f8bdbc49e0be369a2e20e09d57a51c41310543a4128409464a02de0cfe5495c4f58ff60645ceda0afd67a4c90a70bc89fe207269435b35e5b67b86702f864010280820fa08284d09411111111111111111111111111111111111111118080c080a0d4ec563b6568cd42d998fc4134b36933c6568d01533b5adf08769270243c6c7fa072bf7c21eac6bbeae5143371eef26d5e279637f3bd73482b55979d76d935b1e9"
|
|
30
tools/t8n/testdata/33/alloc.json
vendored
30
tools/t8n/testdata/33/alloc.json
vendored
@ -1,30 +0,0 @@
|
|||||||
{
|
|
||||||
"0x8a0a19589531694250d570040a0c4b74576919b8": {
|
|
||||||
"nonce": "0x00",
|
|
||||||
"balance": "0x0de0b6b3a7640000",
|
|
||||||
"code": "0x600060006000600060007310000000000000000000000000000000000000015af1600155600060006000600060007310000000000000000000000000000000000000025af16002553d600060003e600051600355",
|
|
||||||
"storage": {
|
|
||||||
"0x01": "0x0100",
|
|
||||||
"0x02": "0x0100",
|
|
||||||
"0x03": "0x0100"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"0x000000000000000000000000000000000000aaaa": {
|
|
||||||
"nonce": "0x00",
|
|
||||||
"balance": "0x4563918244f40000",
|
|
||||||
"code": "0x58808080600173703c4b2bd70c169f5717101caee543299fc946c75af100",
|
|
||||||
"storage": {}
|
|
||||||
},
|
|
||||||
"0x000000000000000000000000000000000000bbbb": {
|
|
||||||
"nonce": "0x00",
|
|
||||||
"balance": "0x29a2241af62c0000",
|
|
||||||
"code": "0x6042805500",
|
|
||||||
"storage": {}
|
|
||||||
},
|
|
||||||
"0x71562b71999873DB5b286dF957af199Ec94617F7": {
|
|
||||||
"nonce": "0x00",
|
|
||||||
"balance": "0x6124fee993bc0000",
|
|
||||||
"code": "0x",
|
|
||||||
"storage": {}
|
|
||||||
}
|
|
||||||
}
|
|
14
tools/t8n/testdata/33/env.json
vendored
14
tools/t8n/testdata/33/env.json
vendored
@ -1,14 +0,0 @@
|
|||||||
{
|
|
||||||
"currentCoinbase": "0x2adc25665018aa1fe0e6bc666dac8fc2697ff9ba",
|
|
||||||
"currentGasLimit": "71794957647893862",
|
|
||||||
"currentNumber": "1",
|
|
||||||
"currentTimestamp": "1000",
|
|
||||||
"currentRandom": "0",
|
|
||||||
"currentDifficulty": "0",
|
|
||||||
"blockHashes": {},
|
|
||||||
"ommers": [],
|
|
||||||
"currentBaseFee": "7",
|
|
||||||
"parentUncleHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"withdrawals": [],
|
|
||||||
"parentBeaconBlockRoot": "0x0000000000000000000000000000000000000000000000000000000000000000"
|
|
||||||
}
|
|
70
tools/t8n/testdata/33/exp.json
vendored
70
tools/t8n/testdata/33/exp.json
vendored
@ -1,70 +0,0 @@
|
|||||||
{
|
|
||||||
"alloc": {
|
|
||||||
"0x000000000000000000000000000000000000aaaa": {
|
|
||||||
"code": "0x58808080600173703c4b2bd70c169f5717101caee543299fc946c75af100",
|
|
||||||
"balance": "0x4563918244f40000"
|
|
||||||
},
|
|
||||||
"0x000000000000000000000000000000000000bbbb": {
|
|
||||||
"code": "0x6042805500",
|
|
||||||
"balance": "0x29a2241af62c0000"
|
|
||||||
},
|
|
||||||
"0x2adc25665018aa1fe0e6bc666dac8fc2697ff9ba": {
|
|
||||||
"balance": "0x2bf52"
|
|
||||||
},
|
|
||||||
"0x703c4b2bd70c169f5717101caee543299fc946c7": {
|
|
||||||
"code": "0xef0100000000000000000000000000000000000000bbbb",
|
|
||||||
"storage": {
|
|
||||||
"0x0000000000000000000000000000000000000000000000000000000000000042": "0x0000000000000000000000000000000000000000000000000000000000000042"
|
|
||||||
},
|
|
||||||
"balance": "0x1",
|
|
||||||
"nonce": "0x1"
|
|
||||||
},
|
|
||||||
"0x71562b71999873db5b286df957af199ec94617f7": {
|
|
||||||
"code": "0xef0100000000000000000000000000000000000000aaaa",
|
|
||||||
"balance": "0x6124fee993afa30e",
|
|
||||||
"nonce": "0x2"
|
|
||||||
},
|
|
||||||
"0x8a0a19589531694250d570040a0c4b74576919b8": {
|
|
||||||
"code": "0x600060006000600060007310000000000000000000000000000000000000015af1600155600060006000600060007310000000000000000000000000000000000000025af16002553d600060003e600051600355",
|
|
||||||
"storage": {
|
|
||||||
"0x0000000000000000000000000000000000000000000000000000000000000001": "0x0000000000000000000000000000000000000000000000000000000000000100",
|
|
||||||
"0x0000000000000000000000000000000000000000000000000000000000000002": "0x0000000000000000000000000000000000000000000000000000000000000100",
|
|
||||||
"0x0000000000000000000000000000000000000000000000000000000000000003": "0x0000000000000000000000000000000000000000000000000000000000000100"
|
|
||||||
},
|
|
||||||
"balance": "0xde0b6b3a7640000"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"result": {
|
|
||||||
"stateRoot": "0x9fdcacd4510e93c4488e537dc51578b5c6d505771db64a2610036eeb4be7b26f",
|
|
||||||
"txRoot": "0x5d13a0b074e80388dc754da92b22922313a63417b3e25a10f324935e09697a53",
|
|
||||||
"receiptsRoot": "0x504c5d86c34391f70d210e6c482615b391db4bdb9f43479366399d9c5599850a",
|
|
||||||
"logsHash": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",
|
|
||||||
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"receipts": [
|
|
||||||
{
|
|
||||||
"type": "0x4",
|
|
||||||
"root": "0x",
|
|
||||||
"status": "0x1",
|
|
||||||
"cumulativeGasUsed": "0x15fa9",
|
|
||||||
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"logs": null,
|
|
||||||
"transactionHash": "0x0417aab7c1d8a3989190c3167c132876ce9b8afd99262c5a0f9d06802de3d7ef",
|
|
||||||
"contractAddress": "0x0000000000000000000000000000000000000000",
|
|
||||||
"gasUsed": "0x15fa9",
|
|
||||||
"effectiveGasPrice": null,
|
|
||||||
"blockHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
|
|
||||||
"transactionIndex": "0x0"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"currentDifficulty": null,
|
|
||||||
"gasUsed": "0x15fa9",
|
|
||||||
"currentBaseFee": "0x7",
|
|
||||||
"withdrawalsRoot": "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
|
|
||||||
"requestsHash": "0x6036c41849da9c076ed79654d434017387a88fb833c2856b32e18218b3341c5f",
|
|
||||||
"requests": [
|
|
||||||
"0x",
|
|
||||||
"0x",
|
|
||||||
"0x"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
37
tools/t8n/testdata/33/txs.json
vendored
37
tools/t8n/testdata/33/txs.json
vendored
@ -1,37 +0,0 @@
|
|||||||
[
|
|
||||||
{
|
|
||||||
"type": "0x4",
|
|
||||||
"chainId": "0x1",
|
|
||||||
"nonce": "0x0",
|
|
||||||
"to": "0x71562b71999873db5b286df957af199ec94617f7",
|
|
||||||
"gas": "0x7a120",
|
|
||||||
"gasPrice": null,
|
|
||||||
"maxPriorityFeePerGas": "0x2",
|
|
||||||
"maxFeePerGas": "0x12a05f200",
|
|
||||||
"value": "0x0",
|
|
||||||
"input": "0x",
|
|
||||||
"accessList": [],
|
|
||||||
"authorizationList": [
|
|
||||||
{
|
|
||||||
"chainId": "0x1",
|
|
||||||
"address": "0x000000000000000000000000000000000000aaaa",
|
|
||||||
"nonce": "0x1",
|
|
||||||
"v": "0x1",
|
|
||||||
"r": "0xf7e3e597fc097e71ed6c26b14b25e5395bc8510d58b9136af439e12715f2d721",
|
|
||||||
"s": "0x6cf7c3d7939bfdb784373effc0ebb0bd7549691a513f395e3cdabf8602724987"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"chainId": "0x0",
|
|
||||||
"address": "0x000000000000000000000000000000000000bbbb",
|
|
||||||
"nonce": "0x0",
|
|
||||||
"v": "0x1",
|
|
||||||
"r": "0x5011890f198f0356a887b0779bde5afa1ed04e6acb1e3f37f8f18c7b6f521b98",
|
|
||||||
"s": "0x56c3fa3456b103f3ef4a0acb4b647b9cab9ec4bc68fbcdf1e10b49fb2bcbcf61"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"secretKey": "0xb71c71a67e1177ad4e901695e1b4b9ee17ae16c6668d313eac2f96dbcda3f291",
|
|
||||||
"v": "0x0",
|
|
||||||
"r": "0x0",
|
|
||||||
"s": "0x0"
|
|
||||||
}
|
|
||||||
]
|
|
@ -344,15 +344,12 @@ proc exec(ctx: TransContext,
|
|||||||
withdrawalsRoot : header.withdrawalsRoot
|
withdrawalsRoot : header.withdrawalsRoot
|
||||||
)
|
)
|
||||||
|
|
||||||
var excessBlobGas = Opt.none(GasInt)
|
if vmState.com.isCancunOrLater(ctx.env.currentTimestamp):
|
||||||
if ctx.env.currentExcessBlobGas.isSome:
|
|
||||||
excessBlobGas = ctx.env.currentExcessBlobGas
|
|
||||||
elif ctx.env.parentExcessBlobGas.isSome and ctx.env.parentBlobGasUsed.isSome:
|
|
||||||
excessBlobGas = Opt.some calcExcessBlobGas(vmState.parent)
|
|
||||||
|
|
||||||
if excessBlobGas.isSome:
|
|
||||||
result.result.blobGasUsed = Opt.some vmState.blobGasUsed
|
result.result.blobGasUsed = Opt.some vmState.blobGasUsed
|
||||||
result.result.currentExcessBlobGas = excessBlobGas
|
if ctx.env.currentExcessBlobGas.isSome:
|
||||||
|
result.result.currentExcessBlobGas = ctx.env.currentExcessBlobGas
|
||||||
|
elif ctx.env.parentExcessBlobGas.isSome and ctx.env.parentBlobGasUsed.isSome:
|
||||||
|
result.result.currentExcessBlobGas = Opt.some calcExcessBlobGas(vmState.parent)
|
||||||
|
|
||||||
if vmState.com.isPragueOrLater(ctx.env.currentTimestamp):
|
if vmState.com.isPragueOrLater(ctx.env.currentTimestamp):
|
||||||
var allLogs: seq[Log]
|
var allLogs: seq[Log]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user