From 2978c0e8c7750a4e13e4c9a5a6008fd4964fdb3e Mon Sep 17 00:00:00 2001 From: Federico Kunze Date: Mon, 16 Nov 2020 17:34:29 +0100 Subject: [PATCH 1/4] changelog --- CHANGELOG.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 555f61503..bc7223ef4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -35,7 +35,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ # Changelog -## Unreleased +## [v0.3.0] - 2020-11-16 ### API Breaking @@ -48,7 +48,6 @@ corresponding Ethereum API namespace: * `rpc/namespaces/personal`: `personal` namespace. Exposes the `PrivateAccountAPI`. * `rpc/namespaces/net`: `net` namespace. Exposes the `PublicNetAPI`. * `rpc/namespaces/web3`: `web3` namespace. Exposes the `PublicWeb3API`. - * (evm) [\#588](https://github.com/cosmos/ethermint/pull/588) The EVM transaction CLI has been removed in favor of the JSON-RPC. ### Improvements From 63d3ea50d25080496dde0e27e481186e3d7c63fd Mon Sep 17 00:00:00 2001 From: Federico Kunze Date: Tue, 17 Nov 2020 17:30:49 +0100 Subject: [PATCH 2/4] evm: state transitions enabled params --- x/evm/types/errors.go | 6 ++++++ x/evm/types/params.go | 32 +++++++++++++++++++++++++++----- x/evm/types/params_test.go | 7 +++++-- x/evm/types/state_transition.go | 13 +++++++++++-- 4 files changed, 49 insertions(+), 9 deletions(-) diff --git a/x/evm/types/errors.go b/x/evm/types/errors.go index 7754f555f..f52cf8ec6 100644 --- a/x/evm/types/errors.go +++ b/x/evm/types/errors.go @@ -15,4 +15,10 @@ var ( // ErrInvalidChainConfig returns an error resulting from an invalid ChainConfig. ErrInvalidChainConfig = sdkerrors.Register(ModuleName, 4, "invalid chain configuration") + + // ErrCreateDisabled returns an error if the EnableCreate parameter is false. + ErrCreateDisabled = sdkerrors.Register(ModuleName, 5, "EVM Create operation is disabled") + + // ErrCallDisabled returns an error if the EnableCall parameter is false. + ErrCallDisabled = sdkerrors.Register(ModuleName, 6, "EVM Call operation is disabled") ) diff --git a/x/evm/types/params.go b/x/evm/types/params.go index a6c5ad3da..af7be03d3 100644 --- a/x/evm/types/params.go +++ b/x/evm/types/params.go @@ -18,7 +18,9 @@ const ( // Parameter keys var ( - ParamStoreKeyEVMDenom = []byte("EVMDenom") + ParamStoreKeyEVMDenom = []byte("EVMDenom") + ParamStoreKeyEnableCreate = []byte("EnableCreate") + ParamStoreKeyEnableCall = []byte("EnableCall") ) // ParamKeyTable returns the parameter key table. @@ -28,20 +30,30 @@ func ParamKeyTable() params.KeyTable { // Params defines the EVM module parameters type Params struct { + // EVMDenom defines the token denomination used for state transitions on the + // EVM module. EvmDenom string `json:"evm_denom" yaml:"evm_denom"` + // EnableCreate toggles state transitions that use the vm.Create function + EnableCreate bool `json:"enable_create" yaml:"enable_create"` + // EnableCall toggles state transitions that use the vm.Call function + EnableCall bool `json:"enable_call" yaml:"enable_call"` } // NewParams creates a new Params instance -func NewParams(evmDenom string) Params { +func NewParams(evmDenom string, enableCreate, enableCall bool) Params { return Params{ - EvmDenom: evmDenom, + EvmDenom: evmDenom, + EnableCreate: enableCreate, + EnableCall: enableCall, } } // DefaultParams returns default evm parameters func DefaultParams() Params { return Params{ - EvmDenom: ethermint.AttoPhoton, + EvmDenom: ethermint.AttoPhoton, + EnableCreate: true, + EnableCall: true, } } @@ -55,6 +67,8 @@ func (p Params) String() string { func (p *Params) ParamSetPairs() params.ParamSetPairs { return params.ParamSetPairs{ params.NewParamSetPair(ParamStoreKeyEVMDenom, &p.EvmDenom, validateEVMDenom), + params.NewParamSetPair(ParamStoreKeyEnableCreate, &p.EnableCreate, validateBool), + params.NewParamSetPair(ParamStoreKeyEnableCall, &p.EnableCall, validateBool), } } @@ -66,8 +80,16 @@ func (p Params) Validate() error { func validateEVMDenom(i interface{}) error { denom, ok := i.(string) if !ok { - return fmt.Errorf("invalid parameter type: %T", i) + 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 +} diff --git a/x/evm/types/params_test.go b/x/evm/types/params_test.go index 244e360c4..044876ebc 100644 --- a/x/evm/types/params_test.go +++ b/x/evm/types/params_test.go @@ -15,7 +15,7 @@ func TestParamsValidate(t *testing.T) { {"default", DefaultParams(), false}, { "valid", - NewParams("ara"), + NewParams("ara", true, true), false, }, { @@ -45,8 +45,11 @@ func TestParamsValidate(t *testing.T) { func TestParamsValidatePriv(t *testing.T) { require.Error(t, validateEVMDenom(false)) + require.NoError(t, validateEVMDenom("aphoton")) + require.Error(t, validateBool("")) + require.NoError(t, validateBool(true)) } func TestParams_String(t *testing.T) { - require.Equal(t, "evm_denom: aphoton\n", DefaultParams().String()) + require.Equal(t, "evm_denom: aphoton\nenable_create: true\nenable_call: true\n", DefaultParams().String()) } diff --git a/x/evm/types/state_transition.go b/x/evm/types/state_transition.go index 9c203717c..8e0c5acfe 100644 --- a/x/evm/types/state_transition.go +++ b/x/evm/types/state_transition.go @@ -101,8 +101,9 @@ func (st StateTransition) TransitionDb(ctx sdk.Context, config ChainConfig) (*Ex // Clear cache of accounts to handle changes outside of the EVM csdb.UpdateAccounts() - evmDenom := csdb.GetParams().EvmDenom - gasPrice := ctx.MinGasPrices().AmountOf(evmDenom) + params := csdb.GetParams() + + gasPrice := ctx.MinGasPrices().AmountOf(params.EvmDenom) if gasPrice.IsNil() { return nil, errors.New("gas price cannot be nil") } @@ -125,9 +126,17 @@ func (st StateTransition) TransitionDb(ctx sdk.Context, config ChainConfig) (*Ex // create contract or execute call switch contractCreation { case true: + if !params.EnableCreate { + return nil, ErrCreateDisabled + } + ret, contractAddress, leftOverGas, err = evm.Create(senderRef, st.Payload, gasLimit, st.Amount) recipientLog = fmt.Sprintf("contract address %s", contractAddress.String()) default: + if !params.EnableCall { + return nil, ErrCreateDisabled + } + // Increment the nonce for the next transaction (just for evm state transition) csdb.SetNonce(st.Sender, csdb.GetNonce(st.Sender)+1) ret, leftOverGas, err = evm.Call(senderRef, *st.Recipient, st.Payload, gasLimit, st.Amount) From 50ad87162dc862b5051918deece9b041b63b833b Mon Sep 17 00:00:00 2001 From: Federico Kunze Date: Fri, 20 Nov 2020 16:04:35 +0100 Subject: [PATCH 3/4] changelog entry --- CHANGELOG.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index bc7223ef4..193c71e74 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -35,6 +35,12 @@ Ref: https://keepachangelog.com/en/1.0.0/ # Changelog +## Unreleased + +### Improvements + +* (evm) [#603](https://github.com/cosmos/ethermint/pull/603) Add state transition params that enable or disable the EVM `Call` and `Create` operations. + ## [v0.3.0] - 2020-11-16 ### API Breaking From f6e7d20382c2084628539fcf804616f4d15bc98d Mon Sep 17 00:00:00 2001 From: Federico Kunze Date: Fri, 20 Nov 2020 20:20:13 +0100 Subject: [PATCH 4/4] changelog --- CHANGELOG.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 49415bb9d..d26215bad 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -35,11 +35,14 @@ Ref: https://keepachangelog.com/en/1.0.0/ # Changelog -## [v0.3.0] - 2020-11-16 +## Unreleased ### Improvements +* (deps) [\#610](https://github.com/cosmos/ethermint/pull/610) Update Go dependency to 1.15+. +* (deps) [\#608](https://github.com/cosmos/ethermint/pull/608) Bump Cosmos SDK version to [v0.39.2](https://github.com/cosmos/cosmos-sdk/tag/v0.39.2) * (evm) [#603](https://github.com/cosmos/ethermint/pull/603) Add state transition params that enable or disable the EVM `Call` and `Create` operations. +* (deps) [\#602](https://github.com/cosmos/ethermint/pull/602) Bump tendermint version to [v0.33.9](https://github.com/tendermint/tendermint/releases/tag/v0.33.9) ## [v0.3.0] - 2020-11-16