2023-11-01 10:32:09 +07:00
# Nimbus
# Copyright (c) 2023 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.
2023-03-10 17:16:42 -05:00
import
chronos ,
stint ,
2023-08-04 12:10:09 +01:00
eth / common ,
.. / .. / common as dot_common ,
2023-12-12 19:12:56 +00:00
.. / .. / db / ledger ,
2023-03-10 17:16:42 -05:00
.. / types ,
. / data_sources
proc ifNecessaryGetAccount * ( vmState : BaseVMState , address : EthAddress ) : Future [ void ] {. async . } =
2023-10-25 15:03:09 +01:00
if vmState . com . db . localDbOnly : return
2023-12-12 19:12:56 +00:00
await vmState . asyncFactory . ifNecessaryGetAccount ( vmState . com . db , vmState . parent . blockNumber , vmState . parent . stateRoot , address , vmState . stateDB . rawRootHash )
2023-03-10 17:16:42 -05:00
proc ifNecessaryGetCode * ( vmState : BaseVMState , address : EthAddress ) : Future [ void ] {. async . } =
2023-10-25 15:03:09 +01:00
if vmState . com . db . localDbOnly : return
2023-12-12 19:12:56 +00:00
await vmState . asyncFactory . ifNecessaryGetCode ( vmState . com . db , vmState . parent . blockNumber , vmState . parent . stateRoot , address , vmState . stateDB . rawRootHash )
2023-03-10 17:16:42 -05:00
proc ifNecessaryGetSlots * ( vmState : BaseVMState , address : EthAddress , slots : seq [ UInt256 ] ) : Future [ void ] {. async . } =
2023-10-25 15:03:09 +01:00
if vmState . com . db . localDbOnly : return
2023-12-12 19:12:56 +00:00
await vmState . asyncFactory . ifNecessaryGetSlots ( vmState . com . db , vmState . parent . blockNumber , vmState . parent . stateRoot , address , slots , vmState . stateDB . rawRootHash )
2023-03-10 17:16:42 -05:00
proc ifNecessaryGetSlot * ( vmState: BaseVMState, address: EthAddress, slot: UInt256): Future[void] {.async.} =
2023-10-25 15:03:09 +01:00
if vmState . com . db . localDbOnly : return
2023-03-10 17:16:42 -05:00
await ifNecessaryGetSlots ( vmState , address , @ [ slot ] )
proc ifNecessaryGetBlockHeaderByNumber * ( vmState : BaseVMState , blockNumber : BlockNumber ) : Future [ void ] {. async . } =
2023-10-25 15:03:09 +01:00
if vmState . com . db . localDbOnly : return
2023-03-10 17:16:42 -05:00
await vmState . asyncFactory . ifNecessaryGetBlockHeaderByNumber ( vmState . com . db , blockNumber )
2023-04-24 16:59:38 -04:00
#[
FIXME - Adam : This is for later .
proc fetchAndPopulateNodes * ( vmState : BaseVMState , paths : seq [ seq [ seq [ byte ] ] ] , nodeHashes : seq [ Hash256 ] ) : Future [ void ] {. async . } =
2023-03-10 17:16:42 -05:00
if vmState . asyncFactory . maybeDataSource . isSome :
2023-12-12 19:12:56 +00:00
# let stateRoot = vmState.stateDB.rawRootHash # FIXME-Adam: this might not be right, huh? the peer might expect the parent block's final stateRoot, not this weirdo intermediate one
2023-03-10 17:16:42 -05:00
let stateRoot = vmState . parent . stateRoot
let nodes = await vmState . asyncFactory . maybeDataSource . get . fetchNodes ( stateRoot , paths , nodeHashes )
populateDbWithNodes ( vmState . stateDB . rawDb , nodes )
2023-04-24 16:59:38 -04:00
] #
2023-03-10 17:16:42 -05:00
# Sometimes it's convenient to be able to do multiple at once.
proc ifNecessaryGetAccounts * ( vmState : BaseVMState , addresses : seq [ EthAddress ] ) : Future [ void ] {. async . } =
2023-10-25 15:03:09 +01:00
if vmState . com . db . localDbOnly : return
2023-03-10 17:16:42 -05:00
for address in addresses :
await ifNecessaryGetAccount ( vmState , address )
proc ifNecessaryGetCodeForAccounts * ( vmState : BaseVMState , addresses : seq [ EthAddress ] ) : Future [ void ] {. async . } =
2023-10-25 15:03:09 +01:00
if vmState . com . db . localDbOnly : return
2023-03-10 17:16:42 -05:00
for address in addresses :
await ifNecessaryGetCode ( vmState , address )