2021-08-26 10:08:11 +00:00
|
|
|
package keeper
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2022-09-07 06:36:11 +00:00
|
|
|
"github.com/cerc-io/laconicd/x/feemarket/types"
|
2021-08-26 10:08:11 +00:00
|
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
|
|
|
|
2022-10-10 10:38: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-10-10 10:38: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
|
|
|
|
2022-10-10 10:38:33 +00:00
|
|
|
// EndBlock update block gas wanted.
|
2021-12-15 02:10:52 +00:00
|
|
|
// 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 {
|
2022-10-10 10:38:33 +00:00
|
|
|
k.Logger(ctx).Error("block gas meter is nil when setting block gas wanted")
|
2021-08-26 10:08:11 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-10-10 10:38:33 +00:00
|
|
|
gasWanted := k.GetTransientGasWanted(ctx)
|
2021-08-26 10:08:11 +00:00
|
|
|
gasUsed := ctx.BlockGasMeter().GasConsumedToLimit()
|
|
|
|
|
2022-10-10 10:38:33 +00:00
|
|
|
// to prevent BaseFee manipulation we limit the gasWanted so that
|
|
|
|
// gasWanted = max(gasWanted * MinGasMultiplier, gasUsed)
|
|
|
|
// this will be keep BaseFee protected from un-penalized manipulation
|
|
|
|
// more info here https://github.com/cerc-io/laconicd/pull/1105#discussion_r888798925
|
|
|
|
minGasMultiplier := k.GetParams(ctx).MinGasMultiplier
|
|
|
|
limitedGasWanted := sdk.NewDec(int64(gasWanted)).Mul(minGasMultiplier)
|
|
|
|
gasWanted = sdk.MaxDec(limitedGasWanted, sdk.NewDec(int64(gasUsed))).TruncateInt().Uint64()
|
|
|
|
k.SetBlockGasWanted(ctx, gasWanted)
|
|
|
|
|
|
|
|
defer func() {
|
|
|
|
telemetry.SetGauge(float32(gasWanted), "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())),
|
2022-10-10 10:38:33 +00:00
|
|
|
sdk.NewAttribute("amount", fmt.Sprintf("%d", gasWanted)),
|
2021-08-26 10:08:11 +00:00
|
|
|
))
|
|
|
|
}
|