75d553674c
* disable basefee if not london block * add london block check in state transition * fix linter * add unit test * clean code * add changelog
143 lines
3.7 KiB
Go
143 lines
3.7 KiB
Go
package types
|
|
|
|
import (
|
|
"fmt"
|
|
"math/big"
|
|
|
|
"github.com/ethereum/go-ethereum/params"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
paramtypes "github.com/cosmos/cosmos-sdk/x/params/types"
|
|
"github.com/ethereum/go-ethereum/core/vm"
|
|
"github.com/tharsis/ethermint/types"
|
|
)
|
|
|
|
var _ paramtypes.ParamSet = &Params{}
|
|
|
|
const (
|
|
DefaultEVMDenom = types.AttoPhoton
|
|
)
|
|
|
|
// Parameter keys
|
|
var (
|
|
ParamStoreKeyEVMDenom = []byte("EVMDenom")
|
|
ParamStoreKeyEnableCreate = []byte("EnableCreate")
|
|
ParamStoreKeyEnableCall = []byte("EnableCall")
|
|
ParamStoreKeyExtraEIPs = []byte("EnableExtraEIPs")
|
|
ParamStoreKeyChainConfig = []byte("ChainConfig")
|
|
|
|
// AvailableExtraEIPs define the list of all EIPs that can be enabled by the
|
|
// EVM interpreter. These EIPs are applied in order and can override the
|
|
// instruction sets from the latest hard fork enabled by the ChainConfig. For
|
|
// more info check:
|
|
// https://github.com/ethereum/go-ethereum/blob/master/core/vm/interpreter.go#L97
|
|
AvailableExtraEIPs = []int64{1344, 1884, 2200, 2929, 3198, 3529}
|
|
)
|
|
|
|
// ParamKeyTable returns the parameter key table.
|
|
func ParamKeyTable() paramtypes.KeyTable {
|
|
return paramtypes.NewKeyTable().RegisterParamSet(&Params{})
|
|
}
|
|
|
|
// NewParams creates a new Params instance
|
|
func NewParams(evmDenom string, enableCreate, enableCall bool, config ChainConfig, extraEIPs ...int64) Params {
|
|
return Params{
|
|
EvmDenom: evmDenom,
|
|
EnableCreate: enableCreate,
|
|
EnableCall: enableCall,
|
|
ExtraEIPs: extraEIPs,
|
|
ChainConfig: config,
|
|
}
|
|
}
|
|
|
|
// DefaultParams returns default evm parameters
|
|
// ExtraEIPs is empty to prevent overriding the latest hard fork instruction set
|
|
func DefaultParams() Params {
|
|
return Params{
|
|
EvmDenom: DefaultEVMDenom,
|
|
EnableCreate: true,
|
|
EnableCall: true,
|
|
ChainConfig: DefaultChainConfig(),
|
|
ExtraEIPs: nil,
|
|
}
|
|
}
|
|
|
|
// ParamSetPairs returns the parameter set pairs.
|
|
func (p *Params) ParamSetPairs() paramtypes.ParamSetPairs {
|
|
return paramtypes.ParamSetPairs{
|
|
paramtypes.NewParamSetPair(ParamStoreKeyEVMDenom, &p.EvmDenom, validateEVMDenom),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyEnableCreate, &p.EnableCreate, validateBool),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyEnableCall, &p.EnableCall, validateBool),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyExtraEIPs, &p.ExtraEIPs, validateEIPs),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyChainConfig, &p.ChainConfig, validateChainConfig),
|
|
}
|
|
}
|
|
|
|
// Validate performs basic validation on evm parameters.
|
|
func (p Params) Validate() error {
|
|
if err := sdk.ValidateDenom(p.EvmDenom); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := validateEIPs(p.ExtraEIPs); err != nil {
|
|
return err
|
|
}
|
|
|
|
return p.ChainConfig.Validate()
|
|
}
|
|
|
|
// EIPs returns the ExtraEips as a int slice
|
|
func (p Params) EIPs() []int {
|
|
eips := make([]int, len(p.ExtraEIPs))
|
|
for i, eip := range p.ExtraEIPs {
|
|
eips[i] = int(eip)
|
|
}
|
|
return eips
|
|
}
|
|
|
|
func validateEVMDenom(i interface{}) error {
|
|
denom, ok := i.(string)
|
|
if !ok {
|
|
return fmt.Errorf("invalid parameter EVM denom type: %T", i)
|
|
}
|
|
|
|
return sdk.ValidateDenom(denom)
|
|
}
|
|
|
|
func validateBool(i interface{}) error {
|
|
_, ok := i.(bool)
|
|
if !ok {
|
|
return fmt.Errorf("invalid parameter type: %T", i)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func validateEIPs(i interface{}) error {
|
|
eips, ok := i.([]int64)
|
|
if !ok {
|
|
return fmt.Errorf("invalid EIP slice type: %T", i)
|
|
}
|
|
|
|
for _, eip := range eips {
|
|
if !vm.ValidEip(int(eip)) {
|
|
return fmt.Errorf("EIP %d is not activateable, valid EIPS are: %s", eip, vm.ActivateableEips())
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func validateChainConfig(i interface{}) error {
|
|
cfg, ok := i.(ChainConfig)
|
|
if !ok {
|
|
return fmt.Errorf("invalid chain config type: %T", i)
|
|
}
|
|
|
|
return cfg.Validate()
|
|
}
|
|
|
|
func IsLondon(ethConfig *params.ChainConfig, height int64) bool {
|
|
rules := ethConfig.Rules(big.NewInt(height))
|
|
return rules.IsLondon
|
|
}
|