forked from cerc-io/laconicd-deprecated
cc37ed283a
* x/evm - PostTxProcessing use message as callback input * Update CHANGELOG.md * Use core.Message for the PostTxProcessing hook (PR review)
30 lines
897 B
Go
30 lines
897 B
Go
package keeper
|
|
|
|
import (
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
|
|
"github.com/ethereum/go-ethereum/core"
|
|
ethtypes "github.com/ethereum/go-ethereum/core/types"
|
|
"github.com/tharsis/ethermint/x/evm/types"
|
|
)
|
|
|
|
var _ types.EvmHooks = MultiEvmHooks{}
|
|
|
|
// MultiEvmHooks combine multiple evm hooks, all hook functions are run in array sequence
|
|
type MultiEvmHooks []types.EvmHooks
|
|
|
|
// NewMultiEvmHooks combine multiple evm hooks
|
|
func NewMultiEvmHooks(hooks ...types.EvmHooks) MultiEvmHooks {
|
|
return hooks
|
|
}
|
|
|
|
// PostTxProcessing delegate the call to underlying hooks
|
|
func (mh MultiEvmHooks) PostTxProcessing(ctx sdk.Context, msg core.Message, receipt *ethtypes.Receipt) error {
|
|
for i := range mh {
|
|
if err := mh[i].PostTxProcessing(ctx, msg, receipt); err != nil {
|
|
return sdkerrors.Wrapf(err, "EVM hook %T failed", mh[i])
|
|
}
|
|
}
|
|
return nil
|
|
}
|