mirror of
https://github.com/planetmint/planetmint-go.git
synced 2025-06-06 06:06:43 +00:00

* refactor: align variable name with rest of the code Signed-off-by: Julian Strobl <jmastr@mailbox.org>
207 lines
6.1 KiB
Go
207 lines
6.1 KiB
Go
package keeper
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"cosmossdk.io/math"
|
|
db "github.com/cometbft/cometbft-db"
|
|
"github.com/cometbft/cometbft/libs/log"
|
|
"github.com/cosmos/cosmos-sdk/codec"
|
|
"github.com/cosmos/cosmos-sdk/store/prefix"
|
|
storetypes "github.com/cosmos/cosmos-sdk/store/types"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
|
disttypes "github.com/cosmos/cosmos-sdk/x/distribution/types"
|
|
paramtypes "github.com/cosmos/cosmos-sdk/x/params/types"
|
|
|
|
"github.com/planetmint/planetmint-go/config"
|
|
"github.com/planetmint/planetmint-go/util"
|
|
"github.com/planetmint/planetmint-go/x/dao/types"
|
|
)
|
|
|
|
type (
|
|
Keeper struct {
|
|
cdc codec.BinaryCodec
|
|
storeKey storetypes.StoreKey
|
|
memKey storetypes.StoreKey
|
|
challengeKey storetypes.StoreKey
|
|
mintRequestHashKey storetypes.StoreKey
|
|
mintRequestAddressKey storetypes.StoreKey
|
|
accountKeeperKey storetypes.StoreKey
|
|
paramstore paramtypes.Subspace
|
|
|
|
bankKeeper types.BankKeeper
|
|
accountKeeper types.AccountKeeper
|
|
machineKeeper types.MachineKeeper
|
|
authority string
|
|
}
|
|
)
|
|
|
|
func NewKeeper(
|
|
cdc codec.BinaryCodec,
|
|
storeKey,
|
|
memKey storetypes.StoreKey,
|
|
challengeKey storetypes.StoreKey,
|
|
mintRequestHashKey storetypes.StoreKey,
|
|
mintRequestAddressKey storetypes.StoreKey,
|
|
accountKeeperKey storetypes.StoreKey,
|
|
ps paramtypes.Subspace,
|
|
|
|
bankKeeper types.BankKeeper,
|
|
accountKeeper types.AccountKeeper,
|
|
machineKeeper types.MachineKeeper,
|
|
authority string,
|
|
) *Keeper {
|
|
// set KeyTable if it has not already been set
|
|
if !ps.HasKeyTable() {
|
|
ps = ps.WithKeyTable(types.ParamKeyTable())
|
|
}
|
|
|
|
return &Keeper{
|
|
cdc: cdc,
|
|
storeKey: storeKey,
|
|
memKey: memKey,
|
|
challengeKey: challengeKey,
|
|
mintRequestHashKey: mintRequestHashKey,
|
|
mintRequestAddressKey: mintRequestAddressKey,
|
|
accountKeeperKey: accountKeeperKey,
|
|
paramstore: ps,
|
|
|
|
bankKeeper: bankKeeper,
|
|
accountKeeper: accountKeeper,
|
|
machineKeeper: machineKeeper,
|
|
authority: authority,
|
|
}
|
|
}
|
|
|
|
func (k Keeper) Logger(ctx sdk.Context) log.Logger {
|
|
return ctx.Logger().With("module", fmt.Sprintf("x/%s", types.ModuleName))
|
|
}
|
|
|
|
func (k Keeper) DistributeCollectedFees(ctx sdk.Context) {
|
|
ctx = sdk.UnwrapSDKContext(ctx)
|
|
conf := config.GetConfig()
|
|
|
|
balances := make(map[string]math.Int)
|
|
totalStake := math.ZeroInt()
|
|
k.accountKeeper.IterateAccounts(ctx, func(acc authtypes.AccountI) bool {
|
|
addr := acc.GetAddress()
|
|
balance := k.bankKeeper.SpendableCoins(ctx, addr)
|
|
found, stake := balance.Find(conf.StakeDenom)
|
|
if found {
|
|
totalStake = totalStake.Add(stake.Amount)
|
|
balances[addr.String()] = stake.Amount
|
|
}
|
|
return false
|
|
})
|
|
|
|
distAddr := k.accountKeeper.GetModuleAddress(disttypes.ModuleName)
|
|
distSpendableCoins := k.bankKeeper.SpendableCoins(ctx, distAddr)
|
|
found, coinToDistribute := distSpendableCoins.Find(conf.FeeDenom)
|
|
|
|
if found {
|
|
err := k.processBalances(ctx, balances, totalStake, coinToDistribute)
|
|
if err != nil {
|
|
util.GetAppLogger().Error(ctx, "Error processing balances:", err)
|
|
}
|
|
}
|
|
}
|
|
|
|
// Check if the address is blocked
|
|
func (k Keeper) isAddressBlocked(accAddress sdk.AccAddress) bool {
|
|
return k.bankKeeper.BlockedAddr(accAddress)
|
|
}
|
|
|
|
// Send coins from the module to the account
|
|
func (k Keeper) sendCoinsFromModuleToAccount(ctx sdk.Context, accAddress sdk.AccAddress, coinClaim sdk.Coin) error {
|
|
return k.bankKeeper.SendCoinsFromModuleToAccount(ctx, disttypes.ModuleName, accAddress, sdk.NewCoins(coinClaim))
|
|
}
|
|
|
|
// Calculate the claim for an address
|
|
func calculateClaimForAddress(stake math.Int, totalStake math.Int, coinToDistribute sdk.Coin) sdk.Dec {
|
|
decTotalAmountToDistribute := sdk.NewDecFromInt(coinToDistribute.Amount)
|
|
decTotalStake := sdk.NewDecFromInt(totalStake)
|
|
decStake := sdk.NewDecFromInt(stake)
|
|
|
|
share := decStake.Quo(decTotalStake)
|
|
return decTotalAmountToDistribute.Mul(share)
|
|
}
|
|
|
|
func (k Keeper) processBalances(ctx sdk.Context, balances map[string]math.Int, totalStake math.Int, coinToDistribute sdk.Coin) error {
|
|
conf := config.GetConfig()
|
|
for addr, stake := range balances {
|
|
claim := calculateClaimForAddress(stake, totalStake, coinToDistribute)
|
|
|
|
if claim.GTE(sdk.OneDec()) {
|
|
intClaim := claim.TruncateInt()
|
|
coinClaim := sdk.NewCoin(conf.FeeDenom, intClaim)
|
|
|
|
accAddress, err := sdk.AccAddressFromBech32(addr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if !k.isAddressBlocked(accAddress) {
|
|
err = k.sendCoinsFromModuleToAccount(ctx, accAddress, coinClaim)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (k Keeper) SelectPopParticipants(ctx sdk.Context) (challenger string, challengee string) {
|
|
conf := config.GetConfig()
|
|
|
|
var startAccountNumber uint64
|
|
lastPopHeight := ctx.BlockHeight() - int64(conf.PopEpochs)
|
|
lastPop, found := k.LookupChallenge(ctx, lastPopHeight)
|
|
if lastPopHeight > 0 && found {
|
|
lastAccountAddr := sdk.MustAccAddressFromBech32(lastPop.Challengee)
|
|
lastAccount := k.accountKeeper.GetAccount(ctx, lastAccountAddr)
|
|
startAccountNumber = lastAccount.GetAccountNumber() + 1
|
|
}
|
|
|
|
var participants []sdk.AccAddress
|
|
k.iterateAccountsForMachines(ctx, startAccountNumber, &participants, true)
|
|
if len(participants) != 2 {
|
|
k.iterateAccountsForMachines(ctx, startAccountNumber, &participants, false)
|
|
}
|
|
|
|
// Not enough participants
|
|
if len(participants) != 2 {
|
|
return
|
|
}
|
|
|
|
challenger = participants[0].String()
|
|
challengee = participants[1].String()
|
|
|
|
return
|
|
}
|
|
|
|
func (k Keeper) iterateAccountsForMachines(ctx sdk.Context, start uint64, participants *[]sdk.AccAddress, iterateFromStart bool) {
|
|
store := ctx.KVStore(k.accountKeeperKey)
|
|
accountStore := prefix.NewStore(store, authtypes.AccountNumberStoreKeyPrefix)
|
|
var iterator db.Iterator
|
|
if iterateFromStart {
|
|
iterator = accountStore.Iterator(sdk.Uint64ToBigEndian(start), nil)
|
|
} else {
|
|
iterator = accountStore.Iterator(nil, sdk.Uint64ToBigEndian(start))
|
|
}
|
|
defer iterator.Close()
|
|
|
|
for ; iterator.Valid(); iterator.Next() {
|
|
participant := sdk.AccAddress(iterator.Value())
|
|
_, found := k.machineKeeper.GetMachineIndexByAddress(ctx, participant.String())
|
|
if found {
|
|
*participants = append(*participants, participant)
|
|
}
|
|
|
|
if len(*participants) == 2 {
|
|
return
|
|
}
|
|
}
|
|
}
|