Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Firehose #7

Merged
merged 45 commits into from
Oct 23, 2024
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
edd0dc4
feat: add firehose tracer
arrivets Sep 22, 2024
b5b917d
chore: add firehose test case in TestApplyMessageWithConfig
arrivets Sep 23, 2024
8a39df1
chore: fix firehose test case
arrivets Sep 23, 2024
279bd42
chore: make firehose the default tracer
arrivets Sep 23, 2024
f3b5e0b
chore: cleanup comment about default tracer
arrivets Sep 30, 2024
2084cda
chore: move test case with firehose tracer
arrivets Sep 30, 2024
f19c3c0
- add firehose evm tracer hooks
Eduard-Voiculescu Oct 3, 2024
94e8033
Tracer refactoring
Eduard-Voiculescu Oct 4, 2024
5376e54
Adding EndBlock tracer and using the k.evmTracer instead of the trace…
Eduard-Voiculescu Oct 4, 2024
65f117b
Update finalized header when begin block hook is called
Eduard-Voiculescu Oct 4, 2024
7821ea6
Removing unused method and setting header values
Eduard-Voiculescu Oct 4, 2024
5f5cd2c
Update tracer with custom OnCosmosBlockStart and OnCosmosBlockEnd hooks
Eduard-Voiculescu Oct 9, 2024
091c32a
fix block header differences bet/ firehose tracer and eth_getBlock me…
Eduard-Voiculescu Oct 9, 2024
c6b80d9
removing debug log
Eduard-Voiculescu Oct 9, 2024
de3f90e
update statedb tracer
Eduard-Voiculescu Oct 9, 2024
5558c12
adding balance change setBalance changes
Eduard-Voiculescu Oct 9, 2024
929fec3
Update tracer tests for nonce changes, code changes and storage changes
Eduard-Voiculescu Oct 10, 2024
bcb4d47
Bumping cometbft and cosmos-sdk versions
Eduard-Voiculescu Oct 10, 2024
3f8d55e
Update cometbft dependency with sf fork with changes done to PartSetH…
Eduard-Voiculescu Oct 11, 2024
7867d50
Update tracer
Eduard-Voiculescu Oct 15, 2024
b7a2952
Fix on tx end hook call
Eduard-Voiculescu Oct 16, 2024
781d9ac
Fix outdated grpc_query tests
Eduard-Voiculescu Oct 16, 2024
34b4182
Adding firehose trace in the OnStorageChange call
Eduard-Voiculescu Oct 17, 2024
4e2ce71
Adding test for ApplyTransactionWithTracer to check that the hooks ar…
Eduard-Voiculescu Oct 17, 2024
bc9cb03
- address pr comments
Eduard-Voiculescu Oct 17, 2024
610f7b6
Fix issue in tracer not catching correct error in `state_transition.go`
Eduard-Voiculescu Oct 17, 2024
2eb08d9
removing todo
Eduard-Voiculescu Oct 17, 2024
81ed849
removing todo comment
Eduard-Voiculescu Oct 17, 2024
5d807a1
Removing global registry
Eduard-Voiculescu Oct 18, 2024
4a1c994
refactor: removce EVMConfigWithTracer
arrivets Oct 21, 2024
4c4cf62
refactor: comment choice of tracer in prepareTrace
arrivets Oct 21, 2024
ba1afe5
refactor: update comment on NewEVM about RANDAO
arrivets Oct 21, 2024
5d3ad48
chore: add nil check in StateDB.AddLog
arrivets Oct 21, 2024
f865e00
chore: remove duplicate package alias in statedb_test.go
arrivets Oct 22, 2024
6a35fc9
refactor: delete unused LiveTracerRegistry
arrivets Oct 22, 2024
753bad6
refactor: delete unused BlockchainTraceFactory
arrivets Oct 22, 2024
7f52fb5
refactor: change name of methods that get/set tracing hooks in context
arrivets Oct 22, 2024
aa2d647
refactor: fix imports in x/evm/types/tracer.go
arrivets Oct 22, 2024
0803635
refactor: remove unused NewLiveTracer
arrivets Oct 22, 2024
bd3ef46
removing the firehose switch case from the NewTracer method as we are…
Eduard-Voiculescu Oct 22, 2024
7789c56
chore: add tracer in app.go
arrivets Oct 23, 2024
7db3bd1
chore: refactor initializeEVM
arrivets Oct 23, 2024
e942116
chore: define error type for ErrConfigOverrides
arrivets Oct 23, 2024
5be6f4c
chore: update TestApplyMessage
arrivets Oct 23, 2024
ffcfd44
chore: remove manual call to OnNonceChange after evm.Call
arrivets Oct 23, 2024
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
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -84,3 +84,6 @@ contracts/@openzeppelin/*
# direnv
/.envrc
/.direnv

# env file
.env
50 changes: 45 additions & 5 deletions app/app.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import (
"fmt"
"io"
"io/fs"
"math/big"
"net/http"
"os"
"path/filepath"
Expand All @@ -39,6 +40,7 @@ import (
"cosmossdk.io/log"
abci "github.com/cometbft/cometbft/abci/types"
tmos "github.com/cometbft/cometbft/libs/os"
tmproto "github.com/cometbft/cometbft/proto/tendermint/types"
dbm "github.com/cosmos/cosmos-db"

"github.com/cosmos/cosmos-sdk/baseapp"
Expand Down Expand Up @@ -115,7 +117,6 @@ import (
"github.com/cosmos/ibc-go/modules/capability"
capabilitykeeper "github.com/cosmos/ibc-go/modules/capability/keeper"
capabilitytypes "github.com/cosmos/ibc-go/modules/capability/types"

"github.com/cosmos/ibc-go/v8/modules/apps/transfer"
ibctransferkeeper "github.com/cosmos/ibc-go/v8/modules/apps/transfer/keeper"
ibctransfertypes "github.com/cosmos/ibc-go/v8/modules/apps/transfer/types"
Expand All @@ -126,7 +127,9 @@ import (
ibcexported "github.com/cosmos/ibc-go/v8/modules/core/exported"
ibckeeper "github.com/cosmos/ibc-go/v8/modules/core/keeper"
ibctm "github.com/cosmos/ibc-go/v8/modules/light-clients/07-tendermint"

ethcommon "github.com/ethereum/go-ethereum/common"
ethhexutil "github.com/ethereum/go-ethereum/common/hexutil"
ethtypes "github.com/ethereum/go-ethereum/core/types"
"github.com/evmos/ethermint/client/docs"

"github.com/evmos/ethermint/app/ante"
Expand Down Expand Up @@ -480,8 +483,6 @@ func NewEthermintApp(
authAddr,
)

tracer := cast.ToString(appOpts.Get(srvflags.EVMTracer))

// Create Ethermint keepers
feeMarketSs := app.GetSubspace(feemarkettypes.ModuleName)
app.FeeMarketKeeper = feemarketkeeper.NewKeeper(
Expand All @@ -497,7 +498,6 @@ func NewEthermintApp(
appCodec,
keys[evmtypes.StoreKey], okeys[evmtypes.ObjectStoreKey], authtypes.NewModuleAddress(govtypes.ModuleName),
app.AccountKeeper, app.BankKeeper, app.StakingKeeper, app.FeeMarketKeeper,
tracer,
evmSs,
nil,
)
Expand Down Expand Up @@ -1112,3 +1112,43 @@ func initParamsKeeper(appCodec codec.BinaryCodec, legacyAmino *codec.LegacyAmino
paramsKeeper.Subspace(feemarkettypes.ModuleName).WithKeyTable(feemarkettypes.ParamKeyTable())
return paramsKeeper
}

// Call this method in to OnBlockStart call
func TmBlockHeaderToEVM(
arrivets marked this conversation as resolved.
Show resolved Hide resolved
ctx sdk.Context,
block tmproto.Header,
k *evmkeeper.Keeper,
) (header *ethtypes.Header) {
number := big.NewInt(block.Height)
lastHash := ethcommon.BytesToHash(block.LastBlockId.Hash)
appHash := ethcommon.BytesToHash(block.AppHash)
txHash := ethcommon.BytesToHash(block.DataHash)
resultHash := ethcommon.BytesToHash(block.LastResultsHash)
miner := ethcommon.BytesToAddress(block.ProposerAddress)
gasLimit, gasWanted := uint64(0), uint64(0)

header = &ethtypes.Header{
Number: number,
ParentHash: lastHash,
Nonce: ethtypes.BlockNonce{}, // todo: check if this applies to injective
MixDigest: ethcommon.Hash{}, // todo: check if this applies to injective
UncleHash: ethtypes.EmptyUncleHash, // todo: check if this applies to injective
Bloom: ethtypes.Bloom{}, // k.GetBlockBloom(ctx, block.Height), // todo: check how to implement this
Root: appHash,
Coinbase: miner,
Difficulty: big.NewInt(0), // todo: check if this applies to injective
Extra: ethhexutil.Bytes{}, // todo: check if this applies to injective
GasLimit: gasLimit,
GasUsed: gasWanted,
Time: uint64(block.Time.Unix()),
TxHash: txHash,
ReceiptHash: resultHash,
BaseFee: nil, // k.GetBaseFeePerGas(ctx).RoundInt().BigInt(), // todo: check how to implement this
}

return
}

func ptr[T any](t T) *T {
return &t
}
20 changes: 12 additions & 8 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -50,9 +50,10 @@ require (
github.com/tidwall/gjson v1.17.1
github.com/tidwall/sjson v1.2.5
github.com/tyler-smith/go-bip39 v1.1.0
golang.org/x/net v0.27.0
golang.org/x/sync v0.7.0
golang.org/x/text v0.16.0
golang.org/x/exp v0.0.0-20240613232115-7f521ea00fb8
golang.org/x/net v0.29.0
golang.org/x/sync v0.8.0
golang.org/x/text v0.18.0
google.golang.org/genproto/googleapis/api v0.0.0-20240528184218-531527333157
google.golang.org/grpc v1.65.0
google.golang.org/protobuf v1.34.2
Expand Down Expand Up @@ -95,6 +96,7 @@ require (
github.com/btcsuite/btcd/chaincfg/chainhash v1.1.0 // indirect
github.com/cenkalti/backoff/v4 v4.2.1 // indirect
github.com/cespare/xxhash/v2 v2.3.0 // indirect
github.com/chenzhuoyu/iasm v0.9.1 // indirect
github.com/chzyer/readline v1.5.1 // indirect
github.com/cockroachdb/apd/v2 v2.0.2 // indirect
github.com/cockroachdb/errors v1.11.3 // indirect
Expand Down Expand Up @@ -187,6 +189,8 @@ require (
github.com/jmespath/go-jmespath v0.4.0 // indirect
github.com/jmhodges/levigo v1.0.0 // indirect
github.com/klauspost/compress v1.17.7 // indirect
github.com/klauspost/cpuid/v2 v2.2.5 // indirect
github.com/knz/go-libedit v1.10.1 // indirect
github.com/kr/pretty v0.3.1 // indirect
github.com/kr/text v0.2.0 // indirect
github.com/lib/pq v1.10.7 // indirect
Expand All @@ -206,7 +210,7 @@ require (
github.com/oklog/run v1.1.0 // indirect
github.com/olekukonko/tablewriter v0.0.5 // indirect
github.com/outcaste-io/ristretto v0.2.3 // indirect
github.com/pelletier/go-toml/v2 v2.1.1 // indirect
github.com/pelletier/go-toml/v2 v2.2.3 // indirect
github.com/petermattis/goid v0.0.0-20231207134359-e60b3f734c67 // indirect
github.com/philhofer/fwd v1.1.2 // indirect
github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect
Expand Down Expand Up @@ -249,11 +253,10 @@ require (
go.opentelemetry.io/otel/trace v1.24.0 // indirect
go.uber.org/atomic v1.11.0 // indirect
go.uber.org/multierr v1.11.0 // indirect
golang.org/x/crypto v0.25.0 // indirect
golang.org/x/exp v0.0.0-20240613232115-7f521ea00fb8 // indirect
golang.org/x/crypto v0.27.0 // indirect
golang.org/x/oauth2 v0.20.0 // indirect
golang.org/x/sys v0.22.0 // indirect
golang.org/x/term v0.22.0 // indirect
golang.org/x/sys v0.25.0 // indirect
golang.org/x/term v0.24.0 // indirect
golang.org/x/time v0.5.0 // indirect
golang.org/x/tools v0.22.0 // indirect
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 // indirect
Expand All @@ -278,4 +281,5 @@ replace (
github.com/cometbft/cometbft => github.com/InjectiveLabs/cometbft v0.38.11-inj-2
github.com/cosmos/cosmos-sdk => github.com/InjectiveLabs/cosmos-sdk v0.50.9-0.20240904140803-b4127ecb5410
github.com/ethereum/go-ethereum => github.com/InjectiveLabs/go-ethereum v1.9.22-0.20240923100242-5e28e23d353e
nhooyr.io/websocket => github.com/coder/websocket v1.8.10 // replaced as instructed here:https://coder.com/blog/websocket
)
Loading
Loading