2021-08-26 10:08:11 +00:00
|
|
|
package keeper
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
2021-10-15 08:59:26 +00:00
|
|
|
"github.com/tharsis/ethermint/x/feemarket/types"
|
2021-08-26 10:08:11 +00:00
|
|
|
|
2022-06-02 13:04:33 +00:00
|
|
|
"github.com/cosmos/cosmos-sdk/telemetry"
|
2021-08-26 10:08:11 +00:00
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
)
|
|
|
|
|
2021-12-15 02:10:52 +00:00
|
|
|
// BeginBlock updates base fee
|
|
|
|
func (k *Keeper) BeginBlock(ctx sdk.Context, req abci.RequestBeginBlock) {
|
2021-08-26 10:08:11 +00:00
|
|
|
baseFee := k.CalculateBaseFee(ctx)
|
2021-10-15 08:59:26 +00:00
|
|
|
|
|
|
|
// return immediately if base fee is nil
|
2021-08-26 10:08:11 +00:00
|
|
|
if baseFee == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
k.SetBaseFee(ctx, baseFee)
|
|
|
|
|
2022-06-02 13:04:33 +00:00
|
|
|
defer func() {
|
|
|
|
telemetry.SetGauge(float32(baseFee.Int64()), "feemarket", "base_fee")
|
|
|
|
}()
|
|
|
|
|
2021-10-15 08:59:26 +00:00
|
|
|
// Store current base fee in event
|
|
|
|
ctx.EventManager().EmitEvents(sdk.Events{
|
|
|
|
sdk.NewEvent(
|
|
|
|
types.EventTypeFeeMarket,
|
|
|
|
sdk.NewAttribute(types.AttributeKeyBaseFee, baseFee.String()),
|
|
|
|
),
|
|
|
|
})
|
2021-12-15 02:10:52 +00:00
|
|
|
}
|
2021-10-15 08:59:26 +00:00
|
|
|
|
2021-12-15 02:10:52 +00:00
|
|
|
// EndBlock update block gas used.
|
|
|
|
// The EVM end block logic doesn't update the validator set, thus it returns
|
|
|
|
// an empty slice.
|
|
|
|
func (k *Keeper) EndBlock(ctx sdk.Context, req abci.RequestEndBlock) {
|
2021-08-26 10:08:11 +00:00
|
|
|
if ctx.BlockGasMeter() == nil {
|
|
|
|
k.Logger(ctx).Error("block gas meter is nil when setting block gas used")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
gasUsed := ctx.BlockGasMeter().GasConsumedToLimit()
|
|
|
|
|
|
|
|
k.SetBlockGasUsed(ctx, gasUsed)
|
|
|
|
|
2022-06-02 13:04:33 +00:00
|
|
|
defer func() {
|
|
|
|
telemetry.SetGauge(float32(gasUsed), "feemarket", "block_gas")
|
|
|
|
}()
|
|
|
|
|
2021-08-26 10:08:11 +00:00
|
|
|
ctx.EventManager().EmitEvent(sdk.NewEvent(
|
|
|
|
"block_gas",
|
|
|
|
sdk.NewAttribute("height", fmt.Sprintf("%d", ctx.BlockHeight())),
|
|
|
|
sdk.NewAttribute("amount", fmt.Sprintf("%d", ctx.BlockGasMeter().GasConsumedToLimit())),
|
|
|
|
))
|
|
|
|
}
|