Some checks are pending
Build SimApp / build (amd64) (push) Waiting to run
Build SimApp / build (arm64) (push) Waiting to run
CodeQL / Analyze (push) Waiting to run
Build & Push / build (push) Waiting to run
Run Gosec / Gosec (push) Waiting to run
Lint / golangci-lint (push) Waiting to run
Checks dependencies and mocks generation / Check go mod tidy (push) Waiting to run
Checks dependencies and mocks generation / Check up to date mocks (push) Waiting to run
System Tests / setup (push) Waiting to run
System Tests / test-system (push) Blocked by required conditions
System Tests / test-system-legacy (push) Blocked by required conditions
Tests / Code Coverage / split-test-files (push) Waiting to run
Tests / Code Coverage / tests (00) (push) Blocked by required conditions
Tests / Code Coverage / tests (01) (push) Blocked by required conditions
Tests / Code Coverage / tests (02) (push) Blocked by required conditions
Tests / Code Coverage / tests (03) (push) Blocked by required conditions
Tests / Code Coverage / test-integration (push) Waiting to run
Tests / Code Coverage / test-e2e (push) Waiting to run
Tests / Code Coverage / repo-analysis (push) Blocked by required conditions
Tests / Code Coverage / test-sim-nondeterminism (push) Waiting to run
Tests / Code Coverage / test-clientv2 (push) Waiting to run
Tests / Code Coverage / test-core (push) Waiting to run
Tests / Code Coverage / test-depinject (push) Waiting to run
Tests / Code Coverage / test-errors (push) Waiting to run
Tests / Code Coverage / test-math (push) Waiting to run
Tests / Code Coverage / test-schema (push) Waiting to run
Tests / Code Coverage / test-collections (push) Waiting to run
Tests / Code Coverage / test-cosmovisor (push) Waiting to run
Tests / Code Coverage / test-confix (push) Waiting to run
Tests / Code Coverage / test-store (push) Waiting to run
Tests / Code Coverage / test-log (push) Waiting to run
Tests / Code Coverage / test-x-tx (push) Waiting to run
Tests / Code Coverage / test-x-nft (push) Waiting to run
Tests / Code Coverage / test-x-circuit (push) Waiting to run
Tests / Code Coverage / test-x-feegrant (push) Waiting to run
Tests / Code Coverage / test-x-evidence (push) Waiting to run
Tests / Code Coverage / test-x-upgrade (push) Waiting to run
Tests / Code Coverage / test-tools-benchmark (push) Waiting to run
439 lines
15 KiB
Go
439 lines
15 KiB
Go
package keeper
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
|
|
gogotypes "github.com/cosmos/gogoproto/types"
|
|
|
|
storetypes "cosmossdk.io/store/types"
|
|
|
|
"git.cw.tr/mukan-network/mukan-sdk/runtime"
|
|
sdk "git.cw.tr/mukan-network/mukan-sdk/types"
|
|
"git.cw.tr/mukan-network/mukan-sdk/x/distribution/types"
|
|
)
|
|
|
|
// get the delegator withdraw address, defaulting to the delegator address
|
|
func (k Keeper) GetDelegatorWithdrawAddr(ctx context.Context, delAddr sdk.AccAddress) (sdk.AccAddress, error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := store.Get(types.GetDelegatorWithdrawAddrKey(delAddr))
|
|
if b == nil {
|
|
return delAddr, err
|
|
}
|
|
return sdk.AccAddress(b), nil
|
|
}
|
|
|
|
// set the delegator withdraw address
|
|
func (k Keeper) SetDelegatorWithdrawAddr(ctx context.Context, delAddr, withdrawAddr sdk.AccAddress) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Set(types.GetDelegatorWithdrawAddrKey(delAddr), withdrawAddr.Bytes())
|
|
}
|
|
|
|
// delete a delegator withdraw addr
|
|
func (k Keeper) DeleteDelegatorWithdrawAddr(ctx context.Context, delAddr, withdrawAddr sdk.AccAddress) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Delete(types.GetDelegatorWithdrawAddrKey(delAddr))
|
|
}
|
|
|
|
// iterate over delegator withdraw addrs
|
|
func (k Keeper) IterateDelegatorWithdrawAddrs(ctx context.Context, handler func(del, addr sdk.AccAddress) (stop bool)) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
iter := storetypes.KVStorePrefixIterator(runtime.KVStoreAdapter(store), types.DelegatorWithdrawAddrPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
addr := sdk.AccAddress(iter.Value())
|
|
del := types.GetDelegatorWithdrawInfoAddress(iter.Key())
|
|
if handler(del, addr) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// GetPreviousProposerConsAddr returns the proposer consensus address for the
|
|
// current block.
|
|
func (k Keeper) GetPreviousProposerConsAddr(ctx context.Context) (sdk.ConsAddress, error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
bz, err := store.Get(types.ProposerKey)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if bz == nil {
|
|
return nil, errors.New("previous proposer not set")
|
|
}
|
|
|
|
addrValue := gogotypes.BytesValue{}
|
|
err = k.cdc.Unmarshal(bz, &addrValue)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return addrValue.GetValue(), nil
|
|
}
|
|
|
|
// set the proposer public key for this block
|
|
func (k Keeper) SetPreviousProposerConsAddr(ctx context.Context, consAddr sdk.ConsAddress) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
bz := k.cdc.MustMarshal(&gogotypes.BytesValue{Value: consAddr})
|
|
return store.Set(types.ProposerKey, bz)
|
|
}
|
|
|
|
// get the starting info associated with a delegator
|
|
func (k Keeper) GetDelegatorStartingInfo(ctx context.Context, val sdk.ValAddress, del sdk.AccAddress) (period types.DelegatorStartingInfo, err error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := store.Get(types.GetDelegatorStartingInfoKey(val, del))
|
|
if err != nil {
|
|
return period, err
|
|
}
|
|
|
|
err = k.cdc.Unmarshal(b, &period)
|
|
return period, err
|
|
}
|
|
|
|
// set the starting info associated with a delegator
|
|
func (k Keeper) SetDelegatorStartingInfo(ctx context.Context, val sdk.ValAddress, del sdk.AccAddress, period types.DelegatorStartingInfo) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := k.cdc.Marshal(&period)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return store.Set(types.GetDelegatorStartingInfoKey(val, del), b)
|
|
}
|
|
|
|
// check existence of the starting info associated with a delegator
|
|
func (k Keeper) HasDelegatorStartingInfo(ctx context.Context, val sdk.ValAddress, del sdk.AccAddress) (bool, error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Has(types.GetDelegatorStartingInfoKey(val, del))
|
|
}
|
|
|
|
// delete the starting info associated with a delegator
|
|
func (k Keeper) DeleteDelegatorStartingInfo(ctx context.Context, val sdk.ValAddress, del sdk.AccAddress) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Delete(types.GetDelegatorStartingInfoKey(val, del))
|
|
}
|
|
|
|
// iterate over delegator starting infos
|
|
func (k Keeper) IterateDelegatorStartingInfos(ctx context.Context, handler func(val sdk.ValAddress, del sdk.AccAddress, info types.DelegatorStartingInfo) (stop bool)) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.DelegatorStartingInfoPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
var info types.DelegatorStartingInfo
|
|
k.cdc.MustUnmarshal(iter.Value(), &info)
|
|
val, del := types.GetDelegatorStartingInfoAddresses(iter.Key())
|
|
if handler(val, del, info) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// get historical rewards for a particular period
|
|
func (k Keeper) GetValidatorHistoricalRewards(ctx context.Context, val sdk.ValAddress, period uint64) (rewards types.ValidatorHistoricalRewards, err error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := store.Get(types.GetValidatorHistoricalRewardsKey(val, period))
|
|
if err != nil {
|
|
return rewards, err
|
|
}
|
|
|
|
err = k.cdc.Unmarshal(b, &rewards)
|
|
return rewards, err
|
|
}
|
|
|
|
// set historical rewards for a particular period
|
|
func (k Keeper) SetValidatorHistoricalRewards(ctx context.Context, val sdk.ValAddress, period uint64, rewards types.ValidatorHistoricalRewards) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := k.cdc.Marshal(&rewards)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return store.Set(types.GetValidatorHistoricalRewardsKey(val, period), b)
|
|
}
|
|
|
|
// iterate over historical rewards
|
|
func (k Keeper) IterateValidatorHistoricalRewards(ctx context.Context, handler func(val sdk.ValAddress, period uint64, rewards types.ValidatorHistoricalRewards) (stop bool)) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorHistoricalRewardsPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
var rewards types.ValidatorHistoricalRewards
|
|
k.cdc.MustUnmarshal(iter.Value(), &rewards)
|
|
addr, period := types.GetValidatorHistoricalRewardsAddressPeriod(iter.Key())
|
|
if handler(addr, period, rewards) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// delete a historical reward
|
|
func (k Keeper) DeleteValidatorHistoricalReward(ctx context.Context, val sdk.ValAddress, period uint64) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Delete(types.GetValidatorHistoricalRewardsKey(val, period))
|
|
}
|
|
|
|
// delete historical rewards for a validator
|
|
func (k Keeper) DeleteValidatorHistoricalRewards(ctx context.Context, val sdk.ValAddress) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.GetValidatorHistoricalRewardsPrefix(val))
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
store.Delete(iter.Key())
|
|
}
|
|
}
|
|
|
|
// delete all historical rewards
|
|
func (k Keeper) DeleteAllValidatorHistoricalRewards(ctx context.Context) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorHistoricalRewardsPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
store.Delete(iter.Key())
|
|
}
|
|
}
|
|
|
|
// historical reference count (used for testcases)
|
|
func (k Keeper) GetValidatorHistoricalReferenceCount(ctx context.Context) (count uint64) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorHistoricalRewardsPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
var rewards types.ValidatorHistoricalRewards
|
|
k.cdc.MustUnmarshal(iter.Value(), &rewards)
|
|
count += uint64(rewards.ReferenceCount)
|
|
}
|
|
return count
|
|
}
|
|
|
|
// get current rewards for a validator
|
|
func (k Keeper) GetValidatorCurrentRewards(ctx context.Context, val sdk.ValAddress) (rewards types.ValidatorCurrentRewards, err error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := store.Get(types.GetValidatorCurrentRewardsKey(val))
|
|
if err != nil {
|
|
return rewards, err
|
|
}
|
|
|
|
err = k.cdc.Unmarshal(b, &rewards)
|
|
return rewards, err
|
|
}
|
|
|
|
// set current rewards for a validator
|
|
func (k Keeper) SetValidatorCurrentRewards(ctx context.Context, val sdk.ValAddress, rewards types.ValidatorCurrentRewards) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := k.cdc.Marshal(&rewards)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return store.Set(types.GetValidatorCurrentRewardsKey(val), b)
|
|
}
|
|
|
|
// delete current rewards for a validator
|
|
func (k Keeper) DeleteValidatorCurrentRewards(ctx context.Context, val sdk.ValAddress) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Delete(types.GetValidatorCurrentRewardsKey(val))
|
|
}
|
|
|
|
// iterate over current rewards
|
|
func (k Keeper) IterateValidatorCurrentRewards(ctx context.Context, handler func(val sdk.ValAddress, rewards types.ValidatorCurrentRewards) (stop bool)) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorCurrentRewardsPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
var rewards types.ValidatorCurrentRewards
|
|
k.cdc.MustUnmarshal(iter.Value(), &rewards)
|
|
addr := types.GetValidatorCurrentRewardsAddress(iter.Key())
|
|
if handler(addr, rewards) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// get accumulated commission for a validator
|
|
func (k Keeper) GetValidatorAccumulatedCommission(ctx context.Context, val sdk.ValAddress) (commission types.ValidatorAccumulatedCommission, err error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := store.Get(types.GetValidatorAccumulatedCommissionKey(val))
|
|
if err != nil {
|
|
return types.ValidatorAccumulatedCommission{}, err
|
|
}
|
|
|
|
if b == nil {
|
|
return types.ValidatorAccumulatedCommission{}, nil
|
|
}
|
|
|
|
err = k.cdc.Unmarshal(b, &commission)
|
|
if err != nil {
|
|
return types.ValidatorAccumulatedCommission{}, err
|
|
}
|
|
return commission, err
|
|
}
|
|
|
|
// set accumulated commission for a validator
|
|
func (k Keeper) SetValidatorAccumulatedCommission(ctx context.Context, val sdk.ValAddress, commission types.ValidatorAccumulatedCommission) error {
|
|
var (
|
|
bz []byte
|
|
err error
|
|
)
|
|
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
if commission.Commission.IsZero() {
|
|
bz, err = k.cdc.Marshal(&types.ValidatorAccumulatedCommission{})
|
|
} else {
|
|
bz, err = k.cdc.Marshal(&commission)
|
|
}
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return store.Set(types.GetValidatorAccumulatedCommissionKey(val), bz)
|
|
}
|
|
|
|
// delete accumulated commission for a validator
|
|
func (k Keeper) DeleteValidatorAccumulatedCommission(ctx context.Context, val sdk.ValAddress) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Delete(types.GetValidatorAccumulatedCommissionKey(val))
|
|
}
|
|
|
|
// iterate over accumulated commissions
|
|
func (k Keeper) IterateValidatorAccumulatedCommissions(ctx context.Context, handler func(val sdk.ValAddress, commission types.ValidatorAccumulatedCommission) (stop bool)) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorAccumulatedCommissionPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
var commission types.ValidatorAccumulatedCommission
|
|
k.cdc.MustUnmarshal(iter.Value(), &commission)
|
|
addr := types.GetValidatorAccumulatedCommissionAddress(iter.Key())
|
|
if handler(addr, commission) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// get validator outstanding rewards
|
|
func (k Keeper) GetValidatorOutstandingRewards(ctx context.Context, val sdk.ValAddress) (rewards types.ValidatorOutstandingRewards, err error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
bz, err := store.Get(types.GetValidatorOutstandingRewardsKey(val))
|
|
if err != nil {
|
|
return rewards, err
|
|
}
|
|
err = k.cdc.Unmarshal(bz, &rewards)
|
|
return rewards, err
|
|
}
|
|
|
|
// set validator outstanding rewards
|
|
func (k Keeper) SetValidatorOutstandingRewards(ctx context.Context, val sdk.ValAddress, rewards types.ValidatorOutstandingRewards) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := k.cdc.Marshal(&rewards)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return store.Set(types.GetValidatorOutstandingRewardsKey(val), b)
|
|
}
|
|
|
|
// delete validator outstanding rewards
|
|
func (k Keeper) DeleteValidatorOutstandingRewards(ctx context.Context, val sdk.ValAddress) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
return store.Delete(types.GetValidatorOutstandingRewardsKey(val))
|
|
}
|
|
|
|
// iterate validator outstanding rewards
|
|
func (k Keeper) IterateValidatorOutstandingRewards(ctx context.Context, handler func(val sdk.ValAddress, rewards types.ValidatorOutstandingRewards) (stop bool)) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorOutstandingRewardsPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
rewards := types.ValidatorOutstandingRewards{}
|
|
k.cdc.MustUnmarshal(iter.Value(), &rewards)
|
|
addr := types.GetValidatorOutstandingRewardsAddress(iter.Key())
|
|
if handler(addr, rewards) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// get slash event for height
|
|
func (k Keeper) GetValidatorSlashEvent(ctx context.Context, val sdk.ValAddress, height, period uint64) (event types.ValidatorSlashEvent, found bool, err error) {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := store.Get(types.GetValidatorSlashEventKey(val, height, period))
|
|
if err != nil {
|
|
return types.ValidatorSlashEvent{}, false, err
|
|
}
|
|
|
|
if b == nil {
|
|
return types.ValidatorSlashEvent{}, false, nil
|
|
}
|
|
|
|
err = k.cdc.Unmarshal(b, &event)
|
|
if err != nil {
|
|
return types.ValidatorSlashEvent{}, false, err
|
|
}
|
|
|
|
return event, true, nil
|
|
}
|
|
|
|
// set slash event for height
|
|
func (k Keeper) SetValidatorSlashEvent(ctx context.Context, val sdk.ValAddress, height, period uint64, event types.ValidatorSlashEvent) error {
|
|
store := k.storeService.OpenKVStore(ctx)
|
|
b, err := k.cdc.Marshal(&event)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return store.Set(types.GetValidatorSlashEventKey(val, height, period), b)
|
|
}
|
|
|
|
// iterate over slash events between heights, inclusive
|
|
func (k Keeper) IterateValidatorSlashEventsBetween(ctx context.Context, val sdk.ValAddress, startingHeight, endingHeight uint64,
|
|
handler func(height uint64, event types.ValidatorSlashEvent) (stop bool),
|
|
) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := store.Iterator(
|
|
types.GetValidatorSlashEventKeyPrefix(val, startingHeight),
|
|
types.GetValidatorSlashEventKeyPrefix(val, endingHeight+1),
|
|
)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
var event types.ValidatorSlashEvent
|
|
k.cdc.MustUnmarshal(iter.Value(), &event)
|
|
_, height := types.GetValidatorSlashEventAddressHeight(iter.Key())
|
|
if handler(height, event) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// iterate over all slash events
|
|
func (k Keeper) IterateValidatorSlashEvents(ctx context.Context, handler func(val sdk.ValAddress, height uint64, event types.ValidatorSlashEvent) (stop bool)) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorSlashEventPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
var event types.ValidatorSlashEvent
|
|
k.cdc.MustUnmarshal(iter.Value(), &event)
|
|
val, height := types.GetValidatorSlashEventAddressHeight(iter.Key())
|
|
if handler(val, height, event) {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
// delete slash events for a particular validator
|
|
func (k Keeper) DeleteValidatorSlashEvents(ctx context.Context, val sdk.ValAddress) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.GetValidatorSlashEventPrefix(val))
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
store.Delete(iter.Key())
|
|
}
|
|
}
|
|
|
|
// delete all slash events
|
|
func (k Keeper) DeleteAllValidatorSlashEvents(ctx context.Context) {
|
|
store := runtime.KVStoreAdapter(k.storeService.OpenKVStore(ctx))
|
|
iter := storetypes.KVStorePrefixIterator(store, types.ValidatorSlashEventPrefix)
|
|
defer iter.Close()
|
|
for ; iter.Valid(); iter.Next() {
|
|
store.Delete(iter.Key())
|
|
}
|
|
}
|