mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-19 03:25:19 +00:00
e2f515ba9e
* query auction by lot owner * add SavingsRateDistributed to store * v2cdps: filtered cdps query * update v2cdps cli examples * add savings rate dist counter to begin blocker * implement savings rate dist cli query * implement cdp REST queries * minor auction CLI/REST updates * fix auction querier bug * update REST endpoint to 'cdps' * update to savings-rate-dist * update SavingsRateDistributed get/set * update tests * fix savings rate dist rounding errors * 'collateralDenom' -> 'collateralType' * refactor 'v2cdps' -> 'cdps', add ratio param * fix augmented CDP type, msg string() method * fix cdp querier test * filter query results efficiently * querier tests * limit type iteration if owner defined * improve savings rate dist genesis validation * default sdk.Dec{} to sdk.ZeroDec in queries * update condition logic for finding intersection * fix cdp querier filtering * Update kava-4 swagger (#653) * add collateral_type, update cdp params * savings rate, auctions, get cdps * drop owner from AuctionResponse * remove duplicate collateral denom * update query paths with {collateral-type}
133 lines
4.5 KiB
Go
133 lines
4.5 KiB
Go
package keeper
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/cosmos/cosmos-sdk/codec"
|
|
"github.com/cosmos/cosmos-sdk/store/prefix"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/x/params/subspace"
|
|
|
|
"github.com/kava-labs/kava/x/cdp/types"
|
|
)
|
|
|
|
// Keeper keeper for the cdp module
|
|
type Keeper struct {
|
|
key sdk.StoreKey
|
|
cdc *codec.Codec
|
|
paramSubspace subspace.Subspace
|
|
pricefeedKeeper types.PricefeedKeeper
|
|
supplyKeeper types.SupplyKeeper
|
|
auctionKeeper types.AuctionKeeper
|
|
accountKeeper types.AccountKeeper
|
|
maccPerms map[string][]string
|
|
}
|
|
|
|
// NewKeeper creates a new keeper
|
|
func NewKeeper(cdc *codec.Codec, key sdk.StoreKey, paramstore subspace.Subspace, pfk types.PricefeedKeeper,
|
|
ak types.AuctionKeeper, sk types.SupplyKeeper, ack types.AccountKeeper, maccs map[string][]string) Keeper {
|
|
if !paramstore.HasKeyTable() {
|
|
paramstore = paramstore.WithKeyTable(types.ParamKeyTable())
|
|
}
|
|
|
|
return Keeper{
|
|
key: key,
|
|
cdc: cdc,
|
|
paramSubspace: paramstore,
|
|
pricefeedKeeper: pfk,
|
|
auctionKeeper: ak,
|
|
supplyKeeper: sk,
|
|
accountKeeper: ack,
|
|
maccPerms: maccs,
|
|
}
|
|
}
|
|
|
|
// CdpDenomIndexIterator returns an sdk.Iterator for all cdps with matching collateral denom
|
|
func (k Keeper) CdpDenomIndexIterator(ctx sdk.Context, collateralType string) sdk.Iterator {
|
|
store := prefix.NewStore(ctx.KVStore(k.key), types.CdpKeyPrefix)
|
|
db, found := k.GetCollateralTypePrefix(ctx, collateralType)
|
|
if !found {
|
|
panic(fmt.Sprintf("denom %s prefix not found", collateralType))
|
|
}
|
|
return sdk.KVStorePrefixIterator(store, types.DenomIterKey(db))
|
|
}
|
|
|
|
// CdpCollateralRatioIndexIterator returns an sdk.Iterator for all cdps that have collateral denom
|
|
// matching denom and collateral:debt ratio LESS THAN targetRatio
|
|
func (k Keeper) CdpCollateralRatioIndexIterator(ctx sdk.Context, collateralType string, targetRatio sdk.Dec) sdk.Iterator {
|
|
store := prefix.NewStore(ctx.KVStore(k.key), types.CollateralRatioIndexPrefix)
|
|
db, found := k.GetCollateralTypePrefix(ctx, collateralType)
|
|
if !found {
|
|
panic(fmt.Sprintf("denom %s prefix not found", collateralType))
|
|
}
|
|
return store.Iterator(types.CollateralRatioIterKey(db, sdk.ZeroDec()), types.CollateralRatioIterKey(db, targetRatio))
|
|
}
|
|
|
|
// IterateAllCdps iterates over all cdps and performs a callback function
|
|
func (k Keeper) IterateAllCdps(ctx sdk.Context, cb func(cdp types.CDP) (stop bool)) {
|
|
store := prefix.NewStore(ctx.KVStore(k.key), types.CdpKeyPrefix)
|
|
iterator := sdk.KVStorePrefixIterator(store, []byte{})
|
|
defer iterator.Close()
|
|
for ; iterator.Valid(); iterator.Next() {
|
|
var cdp types.CDP
|
|
k.cdc.MustUnmarshalBinaryLengthPrefixed(iterator.Value(), &cdp)
|
|
|
|
if cb(cdp) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// IterateCdpsByCollateralType iterates over cdps with matching denom and performs a callback function
|
|
func (k Keeper) IterateCdpsByCollateralType(ctx sdk.Context, collateralType string, cb func(cdp types.CDP) (stop bool)) {
|
|
iterator := k.CdpDenomIndexIterator(ctx, collateralType)
|
|
|
|
defer iterator.Close()
|
|
for ; iterator.Valid(); iterator.Next() {
|
|
var cdp types.CDP
|
|
k.cdc.MustUnmarshalBinaryLengthPrefixed(iterator.Value(), &cdp)
|
|
if cb(cdp) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// IterateCdpsByCollateralRatio iterate over cdps with collateral denom equal to denom and
|
|
// collateral:debt ratio LESS THAN targetRatio and performs a callback function.
|
|
func (k Keeper) IterateCdpsByCollateralRatio(ctx sdk.Context, collateralType string, targetRatio sdk.Dec, cb func(cdp types.CDP) (stop bool)) {
|
|
iterator := k.CdpCollateralRatioIndexIterator(ctx, collateralType, targetRatio)
|
|
|
|
defer iterator.Close()
|
|
for ; iterator.Valid(); iterator.Next() {
|
|
_, id, _ := types.SplitCollateralRatioKey(iterator.Key())
|
|
cdp, found := k.GetCDP(ctx, collateralType, id)
|
|
if !found {
|
|
panic(fmt.Sprintf("cdp %d does not exist", id))
|
|
}
|
|
if cb(cdp) {
|
|
break
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
// SetSavingsRateDistributed sets the SavingsRateDistributed in the store
|
|
func (k Keeper) SetSavingsRateDistributed(ctx sdk.Context, totalDistributed sdk.Int) {
|
|
store := prefix.NewStore(ctx.KVStore(k.key), types.SavingsRateDistributedKey)
|
|
bz := k.cdc.MustMarshalBinaryLengthPrefixed(totalDistributed)
|
|
store.Set([]byte{}, bz)
|
|
}
|
|
|
|
// GetSavingsRateDistributed gets the SavingsRateDistributed from the store
|
|
func (k Keeper) GetSavingsRateDistributed(ctx sdk.Context) sdk.Int {
|
|
savingsRateDistributed := sdk.ZeroInt()
|
|
store := prefix.NewStore(ctx.KVStore(k.key), types.SavingsRateDistributedKey)
|
|
bz := store.Get([]byte{})
|
|
if bz == nil {
|
|
return savingsRateDistributed
|
|
}
|
|
|
|
k.cdc.MustUnmarshalBinaryLengthPrefixed(bz, &savingsRateDistributed)
|
|
return savingsRateDistributed
|
|
}
|