58 lines
2.1 KiB
Go
58 lines
2.1 KiB
Go
package keeper
|
|
|
|
import (
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/x/distribution/types"
|
|
)
|
|
|
|
// Allocate fees handles distribution of the collected fees
|
|
func (k Keeper) AllocateTokens(ctx sdk.Context, percentVotes sdk.Dec, proposer sdk.ConsAddress) {
|
|
|
|
// get the proposer of this block
|
|
proposerValidator := k.stakeKeeper.ValidatorByConsAddr(ctx, proposer)
|
|
|
|
proposerDist := k.GetValidatorDistInfo(ctx, proposerValidator.GetOperator())
|
|
|
|
// get the fees which have been getting collected through all the
|
|
// transactions in the block
|
|
feesCollected := k.feeCollectionKeeper.GetCollectedFees(ctx)
|
|
feesCollectedDec := types.NewDecCoins(feesCollected)
|
|
|
|
feePool := k.GetFeePool(ctx)
|
|
// Temporary workaround to keep CanWithdrawInvariant happy.
|
|
// General discussions here: https://github.com/cosmos/cosmos-sdk/issues/2906#issuecomment-441867634
|
|
if k.stakeKeeper.GetLastTotalPower(ctx).IsZero() {
|
|
feePool.CommunityPool = feePool.CommunityPool.Plus(feesCollectedDec)
|
|
k.SetFeePool(ctx, feePool)
|
|
k.feeCollectionKeeper.ClearCollectedFees(ctx)
|
|
return
|
|
}
|
|
|
|
// allocated rewards to proposer
|
|
baseProposerReward := k.GetBaseProposerReward(ctx)
|
|
bonusProposerReward := k.GetBonusProposerReward(ctx)
|
|
proposerMultiplier := baseProposerReward.Add(bonusProposerReward.Mul(percentVotes))
|
|
proposerReward := feesCollectedDec.MulDec(proposerMultiplier)
|
|
|
|
// apply commission
|
|
commission := proposerReward.MulDec(proposerValidator.GetCommission())
|
|
remaining := proposerReward.Minus(commission)
|
|
proposerDist.ValCommission = proposerDist.ValCommission.Plus(commission)
|
|
proposerDist.DelPool = proposerDist.DelPool.Plus(remaining)
|
|
|
|
// allocate community funding
|
|
communityTax := k.GetCommunityTax(ctx)
|
|
communityFunding := feesCollectedDec.MulDec(communityTax)
|
|
feePool.CommunityPool = feePool.CommunityPool.Plus(communityFunding)
|
|
|
|
// set the global pool within the distribution module
|
|
poolReceived := feesCollectedDec.Minus(proposerReward).Minus(communityFunding)
|
|
feePool.ValPool = feePool.ValPool.Plus(poolReceived)
|
|
|
|
k.SetValidatorDistInfo(ctx, proposerDist)
|
|
k.SetFeePool(ctx, feePool)
|
|
|
|
// clear the now distributed fees
|
|
k.feeCollectionKeeper.ClearCollectedFees(ctx)
|
|
}
|