mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-18 19:15:19 +00:00
6ea518960a
* optimize cdp begin blocker by removing unnecessary checks, reusing data and prefix stores in loops, and reducing number of repeated calculations * fix panic for new cdp types if both previous accural time and global interest factor are not set * do not touch global interest factor if no CDP's exist; revert to panic if global interest factor is not found since this is an unreachable state by normal keeper operation -- it can only be reached if store is modified outside of public interface and normal operation
66 lines
1.8 KiB
Go
66 lines
1.8 KiB
Go
package cdp
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/cosmos/cosmos-sdk/telemetry"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
abci "github.com/cometbft/cometbft/abci/types"
|
|
|
|
"github.com/kava-labs/kava/x/cdp/keeper"
|
|
"github.com/kava-labs/kava/x/cdp/types"
|
|
pricefeedtypes "github.com/kava-labs/kava/x/pricefeed/types"
|
|
)
|
|
|
|
// BeginBlocker compounds the debt in outstanding cdps and liquidates cdps that are below the required collateralization ratio
|
|
func BeginBlocker(ctx sdk.Context, req abci.RequestBeginBlock, k keeper.Keeper) {
|
|
defer telemetry.ModuleMeasureSince(types.ModuleName, time.Now(), telemetry.MetricKeyBeginBlocker)
|
|
|
|
params := k.GetParams(ctx)
|
|
|
|
// only run CDP liquidations every `LiquidationBlockInterval` blocks
|
|
skipSyncronizeAndLiquidations := ctx.BlockHeight()%params.LiquidationBlockInterval != 0
|
|
|
|
for _, cp := range params.CollateralParams {
|
|
ok := k.UpdatePricefeedStatus(ctx, cp.SpotMarketID)
|
|
if !ok {
|
|
continue
|
|
}
|
|
|
|
ok = k.UpdatePricefeedStatus(ctx, cp.LiquidationMarketID)
|
|
if !ok {
|
|
continue
|
|
}
|
|
|
|
err := k.AccumulateInterest(ctx, cp.Type)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
if skipSyncronizeAndLiquidations {
|
|
ctx.Logger().Debug(fmt.Sprintf("skipping x/cdp SynchronizeInterestForRiskyCDPs and LiquidateCdps for %s", cp.Type))
|
|
continue
|
|
}
|
|
|
|
ctx.Logger().Debug(fmt.Sprintf("running x/cdp SynchronizeInterestForRiskyCDPs and LiquidateCdps for %s", cp.Type))
|
|
|
|
err = k.SynchronizeInterestForRiskyCDPs(ctx, sdk.MaxSortableDec, cp)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
err = k.LiquidateCdps(ctx, cp.LiquidationMarketID, cp.Type, cp.LiquidationRatio, cp.CheckCollateralizationIndexCount)
|
|
if err != nil && !errors.Is(err, pricefeedtypes.ErrNoValidPrice) {
|
|
panic(err)
|
|
}
|
|
}
|
|
|
|
err := k.RunSurplusAndDebtAuctions(ctx)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
}
|