Skip to content
This repository has been archived by the owner on Jun 9, 2024. It is now read-only.

feat(statedb): runtime sdb #1223

Closed
wants to merge 189 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
189 commits
Select commit Hold shift + click to select a range
56ef836
modularize default handler
Sep 20, 2023
4fe840a
lint
Sep 20, 2023
e15fe01
Merge branch 'main' into top-of-block
Sep 22, 2023
e8966a8
Merge branch 'main' into top-of-block
Sep 25, 2023
f03126f
base fee works
Sep 26, 2023
a57dcdd
hacky works
Sep 26, 2023
79c9c5d
init
Sep 26, 2023
af584a0
reduce some of the race conditions
Sep 26, 2023
a0266c0
reduce keeper interface
Sep 26, 2023
ff4045d
ree
Sep 26, 2023
a897bd3
Merge branch 'main' into dev/geth-txpool
Sep 26, 2023
e79d154
ree
Sep 26, 2023
5b5d25e
remove dead file
Sep 26, 2023
8b8c92e
txpool config
Sep 26, 2023
4fb9a05
update app.toml
Sep 26, 2023
988e340
back fee in sort of a jank way
Sep 26, 2023
def8815
bing bong
Sep 26, 2023
4bdfd42
remove more sleeps
Sep 26, 2023
2293a2a
remove zi sleeps
Sep 26, 2023
8d84ac8
Merge branch 'main' into dev/geth-txpool
Sep 26, 2023
cfe5a93
revert solidity change
Sep 27, 2023
9148aa6
remove waitgroup in handler
Sep 27, 2023
977b3a0
add mockery
Sep 27, 2023
fdf5b21
improve handler
Sep 27, 2023
0b75544
undo contract changes
Sep 27, 2023
9088795
mockery to mage
Sep 27, 2023
cd7ac66
improve test a bit
Sep 27, 2023
54eca2b
fix starting handler
Sep 27, 2023
4a73964
empty data dir
Sep 27, 2023
b33abd5
cleanup in keeper
Sep 27, 2023
0f6c2d2
move store package
Sep 27, 2023
1b91ff5
reconfigure configuration plugin
Sep 27, 2023
3f71005
giga cleanup
Sep 27, 2023
4ad1acf
fix tests
Sep 27, 2023
5554a20
bing bong
Sep 27, 2023
9ffc9dd
lint
Sep 27, 2023
511eb6c
bing bong
Sep 27, 2023
8e7d497
order
Sep 27, 2023
b0d8797
Merge branch 'main' into dev/geth-txpool
Sep 27, 2023
61b8e27
format
Sep 27, 2023
a4a40a3
some cleanup
Sep 27, 2023
065a61a
push
Sep 28, 2023
558edc7
remove chain config test from genesis
Sep 28, 2023
5cb4aff
bing bong
Sep 28, 2023
9353158
update app.tomls
Sep 28, 2023
88d7568
some cleanup
Sep 28, 2023
4b5b391
ree
Sep 28, 2023
d002197
comment as reminder to fix hive tomorrow
Sep 28, 2023
289e54a
merge main
Sep 28, 2023
2e0e42a
merge main
Sep 28, 2023
95cd953
fix config import
Sep 28, 2023
754052a
revert genesis.json to main
Sep 28, 2023
26c6b1e
app.toml
Sep 28, 2023
a217ebf
failed tests to 1 hive
Sep 28, 2023
06302f3
some cleanup
Sep 28, 2023
3565443
fix unit test
Sep 28, 2023
428e82b
fix unit test
Sep 28, 2023
82883ab
lint
Sep 28, 2023
1ea7771
some cleanup
Sep 28, 2023
dcdb207
fix test
Sep 28, 2023
47994fd
lint and fix address codec
Sep 28, 2023
0e0b890
push
Sep 28, 2023
8dea165
fix e2e
Sep 28, 2023
4381be2
fix data race in handler
Sep 29, 2023
4ae8b74
lint
Sep 29, 2023
3b83058
lint
Sep 29, 2023
4faa0df
merge main
Sep 29, 2023
2b390bc
fix nil ptr
Sep 29, 2023
847a697
fix
Sep 29, 2023
f20db1b
remove mocks
Sep 29, 2023
70e77f0
Merge branch 'main' into dev/geth-txpool
Sep 29, 2023
5ea5b5a
mockery from main
Sep 29, 2023
f0911fa
reduce diff
Sep 29, 2023
1f07d6f
merge main
Sep 29, 2023
c264bc9
Merge branch 'main' into dev/geth-txpool
Sep 29, 2023
00425ae
ree
Sep 29, 2023
f6cbc7c
fix test
Sep 29, 2023
02524d7
merge main
Sep 29, 2023
b018231
set mempool on the baseapp
Sep 29, 2023
b66eace
set tx pool
Sep 29, 2023
1866675
ree
Sep 29, 2023
00789c3
remove uneeded code
Oct 1, 2023
65a91fa
Merge branch 'main' into dev/geth-txpool
Oct 1, 2023
45e3175
miner poc
Oct 2, 2023
2106a1e
typos
Oct 2, 2023
efb63cb
remove mock engine
Oct 2, 2023
47b5de7
push
Oct 2, 2023
0cc3e14
lint
Oct 2, 2023
b5a2853
doesnt need cosmos bump anymore
Oct 2, 2023
73d5d24
probably still fails
Oct 2, 2023
6ff8a76
1b-1t
Oct 3, 2023
97072ad
merge main
Oct 3, 2023
245a1b7
Merge branch 'main' into dev/geth-txpool
Oct 3, 2023
9083dce
merge dev/geth-txpool
Oct 3, 2023
84c0ed3
merge
Oct 3, 2023
146c123
merge
Oct 3, 2023
18cfefe
beacon consensus engine
Oct 3, 2023
785b1dd
begin moving miner
Oct 3, 2023
51605c1
cleanup and remove txp
Oct 3, 2023
d2aa08e
remove unused function from miner
Oct 3, 2023
bd1daa9
add logger to mp
Oct 3, 2023
8bc764f
fix mempool test
Oct 3, 2023
df986e2
remove unused mock
Oct 3, 2023
22132f8
fix merge
Oct 3, 2023
7c62453
fix hive
Oct 3, 2023
1700ebe
merge main
Oct 3, 2023
8e2a084
merge main
Oct 3, 2023
c1aad43
Merge branch 'main' into dev/geth-txpool
calbera Oct 4, 2023
3851517
Merge branch 'dev/geth-txpool' into dev/miner-episode-1
calbera Oct 4, 2023
d01f1df
ree
Oct 4, 2023
a963038
merge
Oct 4, 2023
cdb66fe
deadcode
Oct 4, 2023
ffcdbbe
merge main
Oct 4, 2023
a96cc8b
l o l
Oct 4, 2023
bd62d89
merge main
Oct 4, 2023
9061ec6
lock fixed
Oct 4, 2023
d9b067f
ree
Oct 4, 2023
29395cd
diff
Oct 4, 2023
4f684cb
push
Oct 4, 2023
8ebfac4
yeet
Oct 4, 2023
745a9d5
calling insert on the blockchain
Oct 4, 2023
84bf502
load last state
Oct 4, 2023
00446d4
linter
Oct 4, 2023
a063c6e
remove gas plugin
Oct 4, 2023
ced5a91
fix hive?
Oct 4, 2023
d9cda9e
for hive test?
Oct 4, 2023
fa68157
revert logs regression
Oct 5, 2023
c5041f3
passes hive
Oct 5, 2023
bd7baea
noop meter
Oct 5, 2023
e8b69ad
Revert "noop meter"
Oct 5, 2023
ab9c451
fix race test
Oct 5, 2023
780ee2a
codecov
Oct 5, 2023
51e706e
merge main
Oct 5, 2023
b4cb889
add miner config
Oct 5, 2023
cc4a644
lint
Oct 5, 2023
2964ec1
feat(statedb): Move precompile setup around (#1187)
Oct 5, 2023
34a2a5c
merge target
Oct 5, 2023
589b048
merge
Oct 5, 2023
f88f15e
improve debuggability
Oct 5, 2023
479d2ba
commit statedb in insert chain
Oct 5, 2023
d4c6fba
commit statedb in insert chain
Oct 5, 2023
ede1575
merge main
Oct 6, 2023
a99ca01
merge
Oct 6, 2023
0d8e7d5
Merge branch 'main' into dev/miner-episode-1
Oct 6, 2023
bc0355e
Merge branch 'dev/miner-episode-1' into miner-1b-t
Oct 6, 2023
69cfe7d
Merge branch 'main' into dev/miner-episode-1
Oct 6, 2023
779a275
Merge branch 'dev/miner-episode-1' into miner-1b-t
Oct 6, 2023
98a35ef
fix
Oct 6, 2023
fc6dac3
bing bong
Oct 6, 2023
34b1255
merge
Oct 6, 2023
0c9d9f9
fix data race in tests
Oct 6, 2023
5d03e96
cleanup
Oct 6, 2023
1babef2
merge main
Oct 6, 2023
4b9f25a
merge
Oct 6, 2023
f319842
merge and remove deadcode
Oct 6, 2023
fb9868e
signers
Oct 6, 2023
b648ed9
oh boy oh boy
Oct 6, 2023
a2db49e
remove more deadcode
Oct 6, 2023
4461b40
Revert "remove more deadcode"
Oct 6, 2023
8a9cc79
ree
Oct 6, 2023
3809d73
ree
Oct 6, 2023
7c510e8
Revert "ree"
Oct 6, 2023
dad12e1
Revert "Revert "ree""
Oct 6, 2023
732eac8
reee
Oct 6, 2023
3d7705a
reee
Oct 6, 2023
b03859d
ree
Oct 6, 2023
fd6100e
C R A C K E D
Oct 6, 2023
94862c8
C R A C K E D
Oct 6, 2023
64cdf1f
fix handler test
Oct 6, 2023
5f8a117
merge main
Oct 7, 2023
259782e
merge
Oct 7, 2023
73ec31c
Merge branch 'main' into miner-1b-t
Oct 8, 2023
a667e53
merge main
Oct 9, 2023
c5aa9d7
Merge branch 'main' into miner-1b-t
Oct 9, 2023
be95588
Merge branch 'main' into miner-1b-t
Oct 9, 2023
7f59b9f
cleanup
Oct 9, 2023
8202f5e
Merge branch 'main' into miner-1b-t
Oct 9, 2023
da6ddb1
coinbase is being set correctly
Oct 10, 2023
bd35d7a
fix test
Oct 10, 2023
675d565
set etherbase
Oct 10, 2023
a6fa652
push
Oct 10, 2023
a705a10
merge
Oct 10, 2023
4cb42f9
lint
Oct 10, 2023
70562f6
Merge branch 'miner-1b-t' into polaris-runtime
Oct 10, 2023
0a87bc3
merge main
Oct 11, 2023
023fe8d
ree
Oct 11, 2023
d836ae6
expose miner and txpool for now
Oct 11, 2023
1bc9e61
commit
Oct 12, 2023
0c6c128
ree
Oct 12, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
22 changes: 11 additions & 11 deletions contracts/scripts/DeployAndCallERC20.sol
Original file line number Diff line number Diff line change
Expand Up @@ -27,20 +27,20 @@ pragma solidity ^0.8.17;

import "../lib/forge-std/src/Script.sol";
import "../src/testing/SolmateERC20.sol";
import "../src/testing/ConsumeGas.sol";

contract DeployAndCallERC20 is Script {
function run() public {
address dropAddress = address(12);
uint256 quantity = 50000;
function run() public {
address dropAddress = address(12);
uint256 quantity = 50000;

vm.startBroadcast();
SolmateERC20 drop = new SolmateERC20();
vm.startBroadcast();
ConsumeGas drop = new ConsumeGas();

for (uint256 i = 0; i < 66; i++) {
quantity += 50000;
drop.mint(dropAddress, quantity);
}

vm.stopBroadcast();
for (uint256 i = 0; i < 10; i++) {
drop.consumeGas(500000);
}

vm.stopBroadcast();
}
}
7 changes: 3 additions & 4 deletions cosmos/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -44,16 +44,15 @@ require (
google.golang.org/genproto/googleapis/api v0.0.0-20230726155614-23370e0ffb3e // indirect
google.golang.org/grpc v1.58.1
google.golang.org/protobuf v1.31.0
pkg.berachain.dev/polaris/contracts v0.0.0-20230928142528-23cc5f141354
pkg.berachain.dev/polaris/eth v0.0.0-20230928142528-23cc5f141354
pkg.berachain.dev/polaris/lib v0.0.0-20230928142528-23cc5f141354
pkg.berachain.dev/polaris/contracts v0.0.0-20231010191645-a5ed99983be4
pkg.berachain.dev/polaris/eth v0.0.0-20231010191645-a5ed99983be4
pkg.berachain.dev/polaris/lib v0.0.0-20231010191645-a5ed99983be4
)

require (
filippo.io/edwards25519 v1.0.0 // indirect
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 // indirect
github.com/99designs/keyring v1.2.1 // indirect
github.com/BurntSushi/toml v1.3.2 // indirect
github.com/DataDog/zstd v1.5.5 // indirect
github.com/Microsoft/go-winio v0.6.1 // indirect
github.com/VictoriaMetrics/fastcache v1.12.1 // indirect
Expand Down
14 changes: 6 additions & 8 deletions cosmos/go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -63,8 +63,6 @@ github.com/99designs/keyring v1.2.1/go.mod h1:fc+wB5KTk9wQ9sDx0kFXB3A0MaeGHM9AwR
github.com/Azure/go-ansiterm v0.0.0-20230124172434-306776ec8161 h1:L/gRVlceqvL25UVaW/CKtUDjefjrs0SPonmDGUVOYP0=
github.com/Azure/go-ansiterm v0.0.0-20230124172434-306776ec8161/go.mod h1:xomTg63KZ2rFqZQzSB4Vz2SUXa1BpHTVz9L5PTmPC4E=
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8=
github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo=
github.com/DataDog/datadog-go v3.2.0+incompatible/go.mod h1:LButxg5PwREeZtORoXG3tL4fMGNddJ+vMq1mwgfaqoQ=
github.com/DataDog/zstd v1.5.5 h1:oWf5W7GtOLgp6bciQYDmhHHjdhYkALu6S/5Ni9ZgSvQ=
Expand Down Expand Up @@ -1461,12 +1459,12 @@ nhooyr.io/websocket v1.8.6/go.mod h1:B70DZP8IakI65RVQ51MsWP/8jndNma26DVA/nFSCgW0
nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50=
pgregory.net/rapid v1.1.0 h1:CMa0sjHSru3puNx+J0MIAuiiEV4N0qj8/cMWGBBCsjw=
pgregory.net/rapid v1.1.0/go.mod h1:PY5XlDGj0+V1FCq0o192FdRhpKHGTRIWBgqjDBTrq04=
pkg.berachain.dev/polaris/contracts v0.0.0-20230928142528-23cc5f141354 h1:ot7e/6InxTBcPq8Rg/4cog4JbsAxnPakaghUaI+vYXY=
pkg.berachain.dev/polaris/contracts v0.0.0-20230928142528-23cc5f141354/go.mod h1:aM6e6GYmu5YPNUWGs0Qy3pL8N5MsRHO3QvcUruwF2Rc=
pkg.berachain.dev/polaris/eth v0.0.0-20230928142528-23cc5f141354 h1:xVRqWkLJmjExDCWHg/mCGFqSif51+eucyP8TJuLseiM=
pkg.berachain.dev/polaris/eth v0.0.0-20230928142528-23cc5f141354/go.mod h1:eI+YNq3Nc4J9Di6RyZNOif5ejWGHmWfxRi/dS8gSE6A=
pkg.berachain.dev/polaris/lib v0.0.0-20230928142528-23cc5f141354 h1:QcNeLF3LUwwaEOsV6fdILiLH+BAsCcO+Um/nU1NsZ1w=
pkg.berachain.dev/polaris/lib v0.0.0-20230928142528-23cc5f141354/go.mod h1:PyX74/6+6XhSJ9gXmE/xFYp1gZCcQ36suVk8hh4s36M=
pkg.berachain.dev/polaris/contracts v0.0.0-20231010191645-a5ed99983be4 h1:q9gSJk2kQQbz/3cPcXGCW+JdQvxAm+7ukcDqzZiUcmw=
pkg.berachain.dev/polaris/contracts v0.0.0-20231010191645-a5ed99983be4/go.mod h1:LwuVx7lVFkIa/EXGNz2536i+YTK/mEU4A1vQJFZ8y4Q=
pkg.berachain.dev/polaris/eth v0.0.0-20231010191645-a5ed99983be4 h1:gOqKP7ZCzIU1NZrwdISnxswAatut/6Xi7JjdSpHbZk8=
pkg.berachain.dev/polaris/eth v0.0.0-20231010191645-a5ed99983be4/go.mod h1:HuT/i4PZCz3ItXAvDWHA31z4OZ10we6RH6xz+Fq0Nlw=
pkg.berachain.dev/polaris/lib v0.0.0-20231010191645-a5ed99983be4 h1:3zGPs5JJpBtysLMNWa5wKEhwC+j3p5AAK0gZ1fWuEc8=
pkg.berachain.dev/polaris/lib v0.0.0-20231010191645-a5ed99983be4/go.mod h1:OcMl9wH8872Q4++ikKXIm1FC4FbuGUWHxrjb6LCzvIY=
rsc.io/binaryregexp v0.2.0/go.mod h1:qTv7/COck+e2FymRvadv62gMdZztPaShugOCi3I+8D8=
rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4=
rsc.io/quote/v3 v3.1.0/go.mod h1:yEA65RcK8LyAZtP9Kv3t0HmxON59tX3rD+tICJqUlj0=
Expand Down
83 changes: 83 additions & 0 deletions cosmos/runtime/depinject.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
// SPDX-License-Identifier: BUSL-1.1
//
// Copyright (C) 2023, Berachain Foundation. All rights reserved.
// Use of this software is govered by the Business Source License included
// in the LICENSE file of this repository and at www.mariadb.com/bsl11.
//
// ANY USE OF THE LICENSED WORK IN VIOLATION OF THIS LICENSE WILL AUTOMATICALLY
// TERMINATE YOUR RIGHTS UNDER THIS LICENSE FOR THE CURRENT AND ALL OTHER
// VERSIONS OF THE LICENSED WORK.
//
// THIS LICENSE DOES NOT GRANT YOU ANY RIGHT IN ANY TRADEMARK OR LOGO OF
// LICENSOR OR ITS AFFILIATES (PROVIDED THAT YOU MAY USE A TRADEMARK OR LOGO OF
// LICENSOR AS EXPRESSLY REQUIRED BY THIS LICENSE).
//
// TO THE EXTENT PERMITTED BY APPLICABLE LAW, THE LICENSED WORK IS PROVIDED ON
// AN “AS IS” BASIS. LICENSOR HEREBY DISCLAIMS ALL WARRANTIES AND CONDITIONS,
// EXPRESS OR IMPLIED, INCLUDING (WITHOUT LIMITATION) WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT, AND
// TITLE.

package runtime

import (
"cosmossdk.io/depinject"
"cosmossdk.io/log"

"pkg.berachain.dev/polaris/cosmos/config"
evmkeeper "pkg.berachain.dev/polaris/cosmos/x/evm/keeper"
ethlog "pkg.berachain.dev/polaris/eth/log"
"pkg.berachain.dev/polaris/eth/polar"
)

// DepInjectInput is the input for the dep inject framework.
type DepInjectInput struct {
depinject.In

Logger log.Logger
EVMKeeper *evmkeeper.Keeper
Config func() *config.Config
}

// DepInjectOutput is the output for the dep inject framework.
type DepInjectOutput struct {
depinject.Out

Polaris *Polaris
}

// New creates a new Polaris runtime from the provided
// dependencies.
func New(input DepInjectInput) DepInjectOutput {
cfg := input.Config()
node, err := polar.NewGethNetworkingStack(&cfg.Node)
if err != nil {
panic(err)
}

polaris := polar.NewWithNetworkingStack(
&cfg.Polar, input.EVMKeeper.Host, node, ethlog.FuncHandler(
func(r *ethlog.Record) error {
polarisGethLogger := input.Logger.With("module", "polaris-geth")
switch r.Lvl { //nolint:nolintlint,exhaustive // linter is bugged.
case ethlog.LvlTrace:
case ethlog.LvlDebug:
polarisGethLogger.Debug(r.Msg, r.Ctx...)
case ethlog.LvlInfo:
polarisGethLogger.Info(r.Msg, r.Ctx...)
case ethlog.LvlWarn:
case ethlog.LvlCrit:
case ethlog.LvlError:
polarisGethLogger.Error(r.Msg, r.Ctx...)
}
return nil
}),
)

return DepInjectOutput{
Polaris: &Polaris{
Polaris: polaris,
EVMKeeper: input.EVMKeeper,
},
}
}
136 changes: 136 additions & 0 deletions cosmos/runtime/runtime.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,136 @@
// SPDX-License-Identifier: BUSL-1.1
//
// Copyright (C) 2023, Berachain Foundation. All rights reserved.
// Use of this software is govered by the Business Source License included
// in the LICENSE file of this repository and at www.mariadb.com/bsl11.
//
// ANY USE OF THE LICENSED WORK IN VIOLATION OF THIS LICENSE WILL AUTOMATICALLY
// TERMINATE YOUR RIGHTS UNDER THIS LICENSE FOR THE CURRENT AND ALL OTHER
// VERSIONS OF THE LICENSED WORK.
//
// THIS LICENSE DOES NOT GRANT YOU ANY RIGHT IN ANY TRADEMARK OR LOGO OF
// LICENSOR OR ITS AFFILIATES (PROVIDED THAT YOU MAY USE A TRADEMARK OR LOGO OF
// LICENSOR AS EXPRESSLY REQUIRED BY THIS LICENSE).
//
// TO THE EXTENT PERMITTED BY APPLICABLE LAW, THE LICENSED WORK IS PROVIDED ON
// AN “AS IS” BASIS. LICENSOR HEREBY DISCLAIMS ALL WARRANTIES AND CONDITIONS,
// EXPRESS OR IMPLIED, INCLUDING (WITHOUT LIMITATION) WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT, AND
// TITLE.

package runtime

import (
"cosmossdk.io/log"
storetypes "cosmossdk.io/store/types"

"github.com/cosmos/cosmos-sdk/baseapp"
"github.com/cosmos/cosmos-sdk/client"
sdk "github.com/cosmos/cosmos-sdk/types"

"github.com/ethereum/go-ethereum/beacon/engine"
"github.com/ethereum/go-ethereum/core/rawdb"
"github.com/ethereum/go-ethereum/ethdb"
"github.com/ethereum/go-ethereum/node"

libtx "pkg.berachain.dev/polaris/cosmos/lib/tx"
"pkg.berachain.dev/polaris/cosmos/miner"
"pkg.berachain.dev/polaris/cosmos/txpool"
evmkeeper "pkg.berachain.dev/polaris/cosmos/x/evm/keeper"
enginep "pkg.berachain.dev/polaris/cosmos/x/evm/plugins/engine"
evmtypes "pkg.berachain.dev/polaris/cosmos/x/evm/types"
coretypes "pkg.berachain.dev/polaris/eth/core/types"
"pkg.berachain.dev/polaris/eth/polar"
)

type Polaris struct {
*polar.Polaris

// polaris keepers
EVMKeeper *evmkeeper.Keeper

// polaris componets
WrappedMiner *miner.Miner
WrappedTxPool *txpool.Mempool

//
db ethdb.Database
}

func (p *Polaris) OpenDB(homeDir string) error {
opts := rawdb.OpenOptions{
Type: "pebble",
Directory: homeDir + "/data/evm.db",
AncientsDirectory: homeDir + "/data/evm_ancients.db",
}

var err error
p.db, err = rawdb.Open(opts)
return err
}

func (p *Polaris) Setup(bApp *baseapp.BaseApp) error {
// SetupPrecompiles is used to setup the precompile contracts post depinject.
if err := p.EVMKeeper.SetupPrecompiles(); err != nil {
return err
}

// Init is used to setup the polaris struct.
if err := p.Polaris.Init(); err != nil {
return err
}

// Setup TxPool Wrapper
p.WrappedTxPool = txpool.New(p.TxPool())
bApp.SetMempool(p.WrappedTxPool)

p.WrappedMiner = miner.New(p.Miner())
bApp.SetPrepareProposal(p.WrappedMiner.PrepareProposal)

bApp.CommitMultiStore()

// TODO: deprecate this
p.EVMKeeper.SetBlockchain(p.Blockchain())

return nil
}

func (p *Polaris) Init(clientCtx client.Context, logger log.Logger) error {
// Initialize services.
p.WrappedMiner.Init(libtx.NewSerializer[*engine.ExecutionPayloadEnvelope](
clientCtx.TxConfig, evmtypes.WrapPayload))

p.WrappedTxPool.Init(logger, clientCtx, libtx.NewSerializer[*coretypes.Transaction](
clientCtx.TxConfig, evmtypes.WrapTx))

// Register services with Polaris.
p.RegisterServices(clientCtx, []node.Lifecycle{
p.WrappedTxPool,
})
return nil
}

// Register Services allows for the application to register lifecycles with the evm
// networking stack.
func (p *Polaris) RegisterServices(clientContext client.Context, lcs []node.Lifecycle) {
// TODO: probably get rid of engine plugin or something and handle rpc methods better.
p.EVMKeeper.Host.GetEnginePlugin().(enginep.Plugin).Start(clientContext)

// Register the services with polaris.
for _, lc := range lcs {
p.RegisterService(lc)
}

// Start the services.
if err := p.StartServices(); err != nil {
panic(err)
}
}

func (p *Polaris) LoadLastState(cms storetypes.CommitMultiStore, appHeight uint64) error {
cmsCtx := sdk.Context{}.
WithMultiStore(cms).
WithGasMeter(storetypes.NewInfiniteGasMeter()).
WithBlockGasMeter(storetypes.NewInfiniteGasMeter()).WithEventManager(sdk.NewEventManager())
return p.Blockchain().LoadLastState(cmsCtx, appHeight)
}
14 changes: 10 additions & 4 deletions cosmos/x/evm/genesis_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ import (
sdk "github.com/cosmos/cosmos-sdk/types"
stakingkeeper "github.com/cosmos/cosmos-sdk/x/staking/keeper"

"github.com/ethereum/go-ethereum/consensus/beacon"

"pkg.berachain.dev/polaris/cosmos/config"
"pkg.berachain.dev/polaris/cosmos/precompile/staking"
testutil "pkg.berachain.dev/polaris/cosmos/testutil"
Expand Down Expand Up @@ -90,6 +92,10 @@ var _ = Describe("", func() {
log.NewTestLogger(GinkgoT()),
cfg,
)
k.SetBlockchain(
core.NewChain(k.Host, beacon.NewFaker()),
)

err = k.SetupPrecompiles()
Expect(err).ToNot(HaveOccurred())
am = evm.NewAppModule(k, ak)
Expand All @@ -112,28 +118,28 @@ var _ = Describe("", func() {
Expect(err).ToNot(HaveOccurred())
})
It("should contain the same genesis header values", func() {
bp := k.Polaris().Host().GetBlockPlugin()
bp := k.Host.GetBlockPlugin()
expectedHeader := ethGen.ToBlock().Header()
Expect(bp.GetHeaderByNumber(0)).To(Equal(expectedHeader))
})
It("should have the correct balances", func() {
sp := k.Polaris().Host().GetStatePlugin()
sp := k.Host.GetStatePlugin()
for addr, acc := range ethGen.Alloc {
balance := sp.GetBalance(addr)
cmp := balance.Cmp(acc.Balance)
Expect(cmp).To(BeZero())
}
})
It("should have the correct code", func() {
sp := k.Polaris().Host().GetStatePlugin()
sp := k.Host.GetStatePlugin()
for addr, acc := range ethGen.Alloc {
code := sp.GetCode(addr)
cmp := bytes.Compare(code, acc.Code)
Expect(cmp).To(BeZero())
}
})
It("should have the correct hash", func() {
sp := k.Polaris().Host().GetStatePlugin()
sp := k.Host.GetStatePlugin()
for addr, acc := range ethGen.Alloc {
for key, expectedHash := range acc.Storage {
actualHash := sp.GetState(addr, key)
Expand Down
30 changes: 30 additions & 0 deletions cosmos/x/evm/keeper/abci.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
// SPDX-License-Identifier: BUSL-1.1
//
// Copyright (C) 2023, Berachain Foundation. All rights reserved.
// Use of this software is govered by the Business Source License included
// in the LICENSE file of this repository and at www.mariadb.com/bsl11.
//
// ANY USE OF THE LICENSED WORK IN VIOLATION OF THIS LICENSE WILL AUTOMATICALLY
// TERMINATE YOUR RIGHTS UNDER THIS LICENSE FOR THE CURRENT AND ALL OTHER
// VERSIONS OF THE LICENSED WORK.
//
// THIS LICENSE DOES NOT GRANT YOU ANY RIGHT IN ANY TRADEMARK OR LOGO OF
// LICENSOR OR ITS AFFILIATES (PROVIDED THAT YOU MAY USE A TRADEMARK OR LOGO OF
// LICENSOR AS EXPRESSLY REQUIRED BY THIS LICENSE).
//
// TO THE EXTENT PERMITTED BY APPLICABLE LAW, THE LICENSED WORK IS PROVIDED ON
// AN “AS IS” BASIS. LICENSOR HEREBY DISCLAIMS ALL WARRANTIES AND CONDITIONS,
// EXPRESS OR IMPLIED, INCLUDING (WITHOUT LIMITATION) WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT, AND
// TITLE.

package keeper

import (
"context"
)

func (k *Keeper) PrepareCheckState(ctx context.Context) error {
k.sp.Prepare(ctx)
return nil
}
Loading