nimbus-eth1/nimbus/beacon/web3_eth_conv.nim
Chirag Parmar 2838191c4f
replace deprecated types (#2704)
* partial commit

* fixes

* remove converters too

* revert changes on nimbus_verified_proxy

* revert changes in converter

* revert changes(re-xport) in rpc_types

* update copyright year

* replace types in other binaries

* chain config bug

* fix rebase conflict imcomplete buffer

* fix more rebase buffers

* remove ditto types and converters

* fix the tests

* update copyright year
2024-10-16 08:34:12 +07:00

304 lines
8.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))
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
# at your option.
# This file may not be copied, modified, or distributed except according to
# those terms.
import
std/[typetraits],
chronicles,
web3/primitives as web3types,
web3/eth_api_types,
web3/engine_api_types,
web3/execution_types,
eth/common/eth_types_rlp,
stew/byteutils,
../utils/utils
import eth/common/eth_types as common
export
primitives
type
Web3Quantity* = web3types.Quantity
Web3ExtraData* = web3types.DynamicBytes[0, 32]
Web3BlockNumber* = Quantity
Web3Tx* = engine_api_types.TypedTransaction
Web3Blob* = engine_api_types.Blob
Web3KZGProof* = engine_api_types.KZGProof
Web3KZGCommitment* = engine_api_types.KZGCommitment
{.push gcsafe, raises:[].}
# ------------------------------------------------------------------------------
# Pretty printers
# ------------------------------------------------------------------------------
proc `$`*(x: Opt[common.Hash32]): string =
if x.isNone: "none"
else: x.get().data.toHex
proc `$`*(x: Opt[Bytes8]): string =
if x.isNone: "none"
else: x.get().toHex
# ------------------------------------------------------------------------------
# Web3 types to Eth types
# ------------------------------------------------------------------------------
template unsafeQuantityToInt64*(q: Web3Quantity): int64 =
int64 q
func u64*(x: Opt[Web3Quantity]): Opt[uint64] =
if x.isNone: Opt.none(uint64)
else: Opt.some(uint64 x.get)
func u256*(x: Web3BlockNumber): UInt256 =
u256(x.uint64)
func u256*(x: common.FixedBytes[32]): UInt256 =
UInt256.fromBytesBE(x.data)
func ethTime*(x: Web3Quantity): common.EthTime =
common.EthTime(x)
func ethGasInt*(x: Web3Quantity): common.GasInt =
common.GasInt x
func ethBlob*(x: Web3ExtraData): seq[byte] =
distinctBase x
func ethWithdrawal*(x: WithdrawalV1): common.Withdrawal =
result.index = x.index.uint64
result.validatorIndex = x.validatorIndex.uint64
result.address = x.address.Address
result.amount = x.amount.uint64
func ethWithdrawals*(list: openArray[WithdrawalV1]):
seq[common.Withdrawal] =
result = newSeqOfCap[common.Withdrawal](list.len)
for x in list:
result.add ethWithdrawal(x)
func ethWithdrawals*(x: Opt[seq[WithdrawalV1]]):
Opt[seq[common.Withdrawal]] =
if x.isNone: Opt.none(seq[common.Withdrawal])
else: Opt.some(ethWithdrawals x.get)
func ethTx*(x: Web3Tx): common.Transaction {.gcsafe, raises:[RlpError].} =
result = rlp.decode(distinctBase x, common.Transaction)
func ethTxs*(list: openArray[Web3Tx]):
seq[common.Transaction] {.gcsafe, raises:[RlpError].} =
result = newSeqOfCap[common.Transaction](list.len)
for x in list:
result.add ethTx(x)
func ethAccessList*(list: openArray[AccessTuple]): common.AccessList =
for x in list:
result.add common.AccessPair(
address : x.address,
storageKeys: x.storageKeys,
)
func ethAccessList*(x: Opt[seq[AccessTuple]]): common.AccessList =
if x.isSome:
return ethAccessList(x.get)
# ------------------------------------------------------------------------------
# Eth types to Web3 types
# ------------------------------------------------------------------------------
func w3Qty*(x: UInt256): Web3Quantity =
Web3Quantity x.truncate(uint64)
func w3Qty*(x: common.EthTime): Web3Quantity =
Web3Quantity x.uint64
func w3Qty*(x: common.EthTime, y: int): Web3Quantity =
Web3Quantity(x + y.EthTime)
func w3Qty*(x: Web3Quantity, y: int): Web3Quantity =
Web3Quantity(x.uint64 + y.uint64)
func w3Qty*(x: Web3Quantity, y: EthTime): Web3Quantity =
Web3Quantity(x.uint64 + y.uint64)
func w3Qty*(x: Web3Quantity, y: uint64): Web3Quantity =
Web3Quantity(x.uint64 + y)
func w3Qty*(x: Opt[uint64]): Opt[Web3Quantity] =
if x.isNone: Opt.none(Web3Quantity)
else: Opt.some(Web3Quantity x.get)
func w3Qty*(x: uint64): Web3Quantity =
Web3Quantity(x)
func w3Qty*(x: int64): Web3Quantity =
Web3Quantity(x)
func w3BlockNumber*(x: Opt[uint64]): Opt[Web3BlockNumber] =
if x.isNone: Opt.none(Web3BlockNumber)
else: Opt.some(Web3BlockNumber x.get)
func w3BlockNumber*(x: uint64): Web3BlockNumber =
Web3BlockNumber(x)
func w3BlockNumber*(x: UInt256): Web3BlockNumber =
Web3BlockNumber x.truncate(uint64)
func w3ExtraData*(x: seq[byte]): Web3ExtraData =
Web3ExtraData x
func w3Withdrawal*(w: common.Withdrawal): WithdrawalV1 =
WithdrawalV1(
index : Web3Quantity w.index,
validatorIndex: Web3Quantity w.validatorIndex,
address : w.address,
amount : Web3Quantity w.amount
)
func w3Withdrawals*(list: openArray[common.Withdrawal]): seq[WithdrawalV1] =
result = newSeqOfCap[WithdrawalV1](list.len)
for x in list:
result.add w3Withdrawal(x)
func w3Withdrawals*(x: Opt[seq[common.Withdrawal]]):
Opt[seq[WithdrawalV1]] =
if x.isNone: Opt.none(seq[WithdrawalV1])
else: Opt.some(w3Withdrawals x.get)
func w3Tx*(tx: common.Transaction): Web3Tx =
Web3Tx rlp.encode(tx)
func w3Txs*(list: openArray[common.Transaction]): seq[Web3Tx] =
result = newSeqOfCap[Web3Tx](list.len)
for tx in list:
result.add w3Tx(tx)
proc w3AccessTuple*(ac: AccessPair): AccessTuple =
AccessTuple(
address: ac.address,
storageKeys: ac.storageKeys
)
proc w3AccessList*(list: openArray[AccessPair]): seq[AccessTuple] =
result = newSeqOfCap[AccessTuple](list.len)
for x in list:
result.add w3AccessTuple(x)
func w3DepositRequest*(x: DepositRequest): DepositRequestV1 =
DepositRequestV1(
pubkey: x.pubkey,
withdrawalCredentials: x.withdrawalCredentials,
amount: w3Qty x.amount,
signature: x.signature,
index: w3Qty x.index,
)
func w3DepositRequests*(reqs: Opt[seq[Request]]): Opt[seq[DepositRequestV1]] =
if reqs.isNone:
return Opt.none(seq[DepositRequestV1])
var res: seq[DepositRequestV1]
for req in reqs.get:
if req.requestType == DepositRequestType:
res.add w3DepositRequest req.deposit
ok(res)
func w3WithdrawalRequest*(x: WithdrawalRequest): WithdrawalRequestV1 =
WithdrawalRequestV1(
sourceAddress: x.sourceAddress,
validatorPubkey: x.validatorPubkey,
amount: w3Qty x.amount,
)
func w3WithdrawalRequests*(reqs: Opt[seq[Request]]): Opt[seq[WithdrawalRequestV1]] =
if reqs.isNone:
return Opt.none(seq[WithdrawalRequestV1])
var res: seq[WithdrawalRequestV1]
for req in reqs.get:
if req.requestType == WithdrawalRequestType:
res.add w3WithdrawalRequest req.withdrawal
ok(res)
func w3ConsolidationRequest*(x: ConsolidationRequest): ConsolidationRequestV1 =
ConsolidationRequestV1(
sourceAddress: x.sourceAddress,
sourcePubkey: x.sourcePubkey,
targetPubkey: x.targetPubkey,
)
func w3ConsolidationRequests*(reqs: Opt[seq[Request]]): Opt[seq[ConsolidationRequestV1]] =
if reqs.isNone:
return Opt.none(seq[ConsolidationRequestV1])
var res: seq[ConsolidationRequestV1]
for req in reqs.get:
if req.requestType == ConsolidationRequestType:
res.add w3ConsolidationRequest req.consolidation
ok(res)
func ethRequest*(x: DepositRequestV1): Request =
Request(
requestType: DepositRequestType,
deposit: DepositRequest(
pubkey: x.pubkey,
withdrawalCredentials: x.withdrawalCredentials,
amount: uint64 x.amount,
signature: x.signature,
index: uint64 x.index,
)
)
func ethRequest*(x: WithdrawalRequestV1): Request =
Request(
requestType: WithdrawalRequestType,
withdrawal: WithDrawalRequest(
sourceAddress: x.sourceAddress,
validatorPubkey: x.validatorPubkey,
amount: uint64 x.amount,
)
)
func ethRequest*(x: ConsolidationRequestV1): Request =
Request(
requestType: ConsolidationRequestType,
consolidation: ConsolidationRequest(
sourceAddress: x.sourceAddress,
sourcePubkey: x.sourcePubkey,
targetPubkey: x.targetPubkey,
)
)
func ethRequests*(p: ExecutionPayload): Opt[seq[Request]] =
if p.depositRequests.isNone and
p.withdrawalRequests.isNone and
p.consolidationRequests.isNone:
return Opt.none(seq[Request])
var res: seq[Request]
if p.depositRequests.isSome:
for x in p.depositRequests.get:
res.add ethRequest(x)
if p.withdrawalRequests.isSome:
for x in p.withdrawalRequests.get:
res.add ethRequest(x)
if p.consolidationRequests.isSome:
for x in p.consolidationRequests.get:
res.add ethRequest(x)
ok(res)
chronicles.formatIt(Quantity): $(distinctBase it)