diff --git a/proto/alliance/alliance/params.proto b/proto/alliance/alliance/params.proto index d3a1d14..0c77bb6 100644 --- a/proto/alliance/alliance/params.proto +++ b/proto/alliance/alliance/params.proto @@ -34,4 +34,5 @@ message RewardHistory { (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", (gogoproto.nullable) = false ]; + string alliance = 3; } \ No newline at end of file diff --git a/x/alliance/keeper/asset.go b/x/alliance/keeper/asset.go index a8ccbce..37ca5a2 100644 --- a/x/alliance/keeper/asset.go +++ b/x/alliance/keeper/asset.go @@ -21,10 +21,6 @@ func (k Keeper) InitializeAllianceAssets(ctx sdk.Context, assets []*types.Allian continue } asset.IsInitialized = true - k.IterateAllianceValidatorInfo(ctx, func(valAddr sdk.ValAddress, info types.AllianceValidatorInfo) bool { - k.CreateInitialRewardWeightChangeSnapshot(ctx, asset.Denom, valAddr, info) - return false - }) k.SetAsset(ctx, *asset) } } @@ -343,14 +339,6 @@ func (k Keeper) SetRewardWeightChangeSnapshot(ctx sdk.Context, asset types.Allia k.setRewardWeightChangeSnapshot(ctx, asset.Denom, val.GetOperator(), uint64(ctx.BlockHeight()), snapshot) } -func (k Keeper) CreateInitialRewardWeightChangeSnapshot(ctx sdk.Context, denom string, valAddr sdk.ValAddress, info types.AllianceValidatorInfo) { - snapshot := types.RewardWeightChangeSnapshot{ - PrevRewardWeight: sdk.ZeroDec(), - RewardHistories: info.GlobalRewardHistory, - } - k.setRewardWeightChangeSnapshot(ctx, denom, valAddr, uint64(ctx.BlockHeight()), snapshot) -} - func (k Keeper) setRewardWeightChangeSnapshot(ctx sdk.Context, denom string, valAddr sdk.ValAddress, height uint64, snapshot types.RewardWeightChangeSnapshot) { key := types.GetRewardWeightChangeSnapshotKey(denom, valAddr, height) store := ctx.KVStore(k.storeKey) diff --git a/x/alliance/keeper/reward.go b/x/alliance/keeper/reward.go index a513817..486228a 100644 --- a/x/alliance/keeper/reward.go +++ b/x/alliance/keeper/reward.go @@ -88,8 +88,8 @@ func (k Keeper) ClaimDelegationRewards( // It takes past reward_rate changes into account by using the RewardRateChangeSnapshot entry func (k Keeper) CalculateDelegationRewards(ctx sdk.Context, delegation types.Delegation, val types.AllianceValidator, asset types.AllianceAsset) (sdk.Coins, types.RewardHistories, error) { totalRewards := sdk.NewCoins() - currentRewardHistory := types.NewRewardHistories(val.GlobalRewardHistory) - delegationRewardHistories := types.NewRewardHistories(delegation.RewardHistory) + currentRewardHistory := types.NewRewardHistories(val.GlobalRewardHistory).GetIndexByAlliance(asset.Denom) + delegationRewardHistories := types.NewRewardHistories(delegation.RewardHistory).GetIndexByAlliance(asset.Denom) // If there are reward rate changes between last and current claim, sequentially claim with the help of the snapshots snapshotIter := k.IterateWeightChangeSnapshot(ctx, asset.Denom, val.GetOperator(), delegation.LastRewardClaimHeight) for ; snapshotIter.Valid(); snapshotIter.Next() { @@ -113,15 +113,22 @@ func accumulateRewards(latestRewardHistories types.RewardHistories, rewardHistor delegationTokens := sdk.NewDecFromInt(types.GetDelegationTokens(delegation, validator, asset).Amount) for _, history := range latestRewardHistories { - rewardHistory, found := rewardHistories.GetIndexByDenom(history.Denom) + rewardHistory, found := rewardHistories.GetIndexByDenom(history.Denom, history.Alliance) if !found { rewardHistory.Denom = history.Denom + rewardHistory.Alliance = history.Alliance rewardHistory.Index = sdk.ZeroDec() } if rewardHistory.Index.GTE(history.Index) { continue } - claimWeight := delegationTokens.Mul(rewardWeight) + var claimWeight sdk.Dec + // Handle legacy reward history that does not have a specific alliance + if rewardHistory.Alliance == "" { + claimWeight = delegationTokens.Mul(rewardWeight) + } else { + claimWeight = delegationTokens + } totalClaimable := (history.Index.Sub(rewardHistory.Index)).Mul(claimWeight) rewardHistory.Index = history.Index rewards = rewards.Add(sdk.NewCoin(history.Denom, totalClaimable.TruncateInt())) @@ -140,22 +147,35 @@ func (k Keeper) AddAssetsToRewardPool(ctx sdk.Context, from sdk.AccAddress, val if len(val.TotalDelegatorShares) == 0 { return nil } + alliances := k.GetAllAssets(ctx) - totalAssetWeight := k.totalAssetWeight(ctx, val) - if totalAssetWeight.IsZero() { - // Do nothing since there are no assets to distribute rewards to - return nil + // Get total reward weight to normalize weights + totalRewardWeight := sdk.NewDec(0) + for _, asset := range alliances { + if shouldSkipRewardsToAsset(ctx, *asset, val) { + continue + } + totalRewardWeight = totalRewardWeight.Add(asset.RewardWeight) } - for _, c := range coins { - rewardHistory, found := rewardHistories.GetIndexByDenom(c.Denom) - if !found { - rewardHistories = append(rewardHistories, types.RewardHistory{ - Denom: c.Denom, - Index: sdk.NewDecFromInt(c.Amount).Quo(totalAssetWeight), - }) - } else { - rewardHistory.Index = rewardHistory.Index.Add(sdk.NewDecFromInt(c.Amount).Quo(totalAssetWeight)) + for _, asset := range alliances { + if shouldSkipRewardsToAsset(ctx, *asset, val) { + continue + } + normalizedWeight := asset.RewardWeight.Quo(totalRewardWeight) + for _, c := range coins { + rewardHistory, found := rewardHistories.GetIndexByDenom(c.Denom, asset.Denom) + totalTokens := val.TotalTokensWithAsset(*asset) + difference := sdk.NewDecFromInt(c.Amount).Mul(normalizedWeight).Quo(totalTokens) + if !found { + rewardHistories = append(rewardHistories, types.RewardHistory{ + Denom: c.Denom, + Alliance: asset.Denom, + Index: difference, + }) + } else { + rewardHistory.Index = rewardHistory.Index.Add(difference) + } } } @@ -169,18 +189,6 @@ func (k Keeper) AddAssetsToRewardPool(ctx sdk.Context, from sdk.AccAddress, val return nil } -func (k Keeper) totalAssetWeight(ctx sdk.Context, val types.AllianceValidator) sdk.Dec { - total := sdk.ZeroDec() - for _, token := range val.TotalDelegatorShares { - asset, found := k.GetAssetByDenom(ctx, token.Denom) - if !found { - continue - } - if !asset.RewardsStarted(ctx.BlockTime()) { - continue - } - totalValTokens := val.TotalTokensWithAsset(asset) - total = total.Add(asset.RewardWeight.Mul(totalValTokens)) - } - return total +func shouldSkipRewardsToAsset(ctx sdk.Context, asset types.AllianceAsset, val types.AllianceValidator) bool { + return asset.TotalTokens.IsZero() || !asset.RewardsStarted(ctx.BlockTime()) || val.TotalTokensWithAsset(asset).IsZero() } diff --git a/x/alliance/keeper/tests/grpc_query_test.go b/x/alliance/keeper/tests/grpc_query_test.go index 23e36f5..f68c1a8 100644 --- a/x/alliance/keeper/tests/grpc_query_test.go +++ b/x/alliance/keeper/tests/grpc_query_test.go @@ -340,7 +340,7 @@ func TestClaimQueryReward(t *testing.T) { Rewards: []sdk.Coin{ { Denom: ULunaAlliance, - Amount: math.NewInt(32666), + Amount: math.NewInt(32665), }, }, }, queryDelegation) diff --git a/x/alliance/keeper/tests/reward_test.go b/x/alliance/keeper/tests/reward_test.go index cdc8f6a..e656c38 100644 --- a/x/alliance/keeper/tests/reward_test.go +++ b/x/alliance/keeper/tests/reward_test.go @@ -55,12 +55,12 @@ func TestRewardPoolAndGlobalIndex(t *testing.T) { user2 := addrs[1] // Mint tokens - err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(4000_000)))) + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(5000_000)))) require.NoError(t, err) - err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake2", sdk.NewInt(4000_000)))) + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake2", sdk.NewInt(5000_000)))) require.NoError(t, err) coin := app.BankKeeper.GetBalance(ctx, mintPoolAddr, "stake") - require.Equal(t, sdk.NewCoin("stake", sdk.NewInt(4000_000)), coin) + require.Equal(t, sdk.NewCoin("stake", sdk.NewInt(5000_000)), coin) _, err = app.AllianceKeeper.Delegate(ctx, user1, val1, sdk.NewCoin(AllianceDenom, sdk.NewInt(1000_000))) require.NoError(t, err) @@ -81,8 +81,9 @@ func TestRewardPoolAndGlobalIndex(t *testing.T) { globalIndices := types.NewRewardHistories(val1.GlobalRewardHistory) require.Equal(t, types.RewardHistories{ types.RewardHistory{ - Denom: "stake", - Index: sdk.NewDec(1), + Denom: "stake", + Alliance: AllianceDenom, + Index: sdk.NewDec(2), }, }, globalIndices) @@ -94,32 +95,49 @@ func TestRewardPoolAndGlobalIndex(t *testing.T) { require.NoError(t, err) // Transfer to reward pool - err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(2000_000)))) + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(2_400_000)))) require.NoError(t, err) globalIndices = types.NewRewardHistories(val1.GlobalRewardHistory) require.Equal(t, types.RewardHistories{ types.RewardHistory{ - Denom: "stake", - Index: sdk.NewDec(14).Quo(sdk.NewDec(12)), + Denom: "stake", + Alliance: AllianceDenom, + Index: sdk.MustNewDecFromStr("2.400000000000000001"), + }, + types.RewardHistory{ + Denom: "stake", + Alliance: AllianceDenomTwo, + Index: sdk.MustNewDecFromStr("1.999999999999999999"), }, }, globalIndices) // Transfer another token to reward pool - err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake2", sdk.NewInt(4000_000)))) + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake2", sdk.NewInt(1_200_000)))) require.NoError(t, err) // Expect global index to be updated - // 14/12 + 4/12 = 18/12 globalIndices = types.NewRewardHistories(val1.GlobalRewardHistory) require.Equal(t, types.RewardHistories{ types.RewardHistory{ - Denom: "stake", - Index: sdk.NewDec(14).Quo(sdk.NewDec(12)), + Denom: "stake", + Alliance: AllianceDenom, + Index: sdk.MustNewDecFromStr("2.400000000000000001"), + }, + types.RewardHistory{ + Denom: "stake", + Alliance: AllianceDenomTwo, + Index: sdk.MustNewDecFromStr("1.999999999999999999"), }, types.RewardHistory{ - Denom: "stake2", - Index: sdk.NewDec(4).Quo(sdk.NewDec(12)), + Denom: "stake2", + Alliance: AllianceDenom, + Index: sdk.MustNewDecFromStr("0.2"), + }, + types.RewardHistory{ + Denom: "stake2", + Alliance: AllianceDenomTwo, + Index: sdk.MustNewDecFromStr("1.0"), }, }, globalIndices) } @@ -130,7 +148,7 @@ func TestClaimRewards(t *testing.T) { Params: types.DefaultParams(), Assets: []types.AllianceAsset{ types.NewAllianceAsset(AllianceDenom, sdk.NewDec(2), sdk.NewDec(0), sdk.NewDec(5), sdk.NewDec(0), ctx.BlockTime()), - types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(10), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime()), + types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(8), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime()), }, }) @@ -150,9 +168,9 @@ func TestClaimRewards(t *testing.T) { user2 := addrs[1] // Mint tokens - err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(4000_000)))) + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(5000_000)))) require.NoError(t, err) - err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake2", sdk.NewInt(4000_000)))) + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake2", sdk.NewInt(5000_000)))) require.NoError(t, err) // New delegation from user 1 @@ -163,7 +181,7 @@ func TestClaimRewards(t *testing.T) { require.NoError(t, err) // Transfer to reward pool - err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(2000_000)))) + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(1000_000)))) require.NoError(t, err) // New delegation from user 2 @@ -174,7 +192,7 @@ func TestClaimRewards(t *testing.T) { require.NoError(t, err) // Transfer to reward pool - err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(2000_000)))) + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(1000_000)))) require.NoError(t, err) asset, _ := app.AllianceKeeper.GetAssetByDenom(ctx, AllianceDenom) @@ -196,12 +214,24 @@ func TestClaimRewards(t *testing.T) { require.Equal(t, types.NewRewardHistories([]types.RewardHistory{ { - Denom: "stake", - Index: sdk.MustNewDecFromStr("1.166666666666666667"), + Denom: "stake", + Index: sdk.MustNewDecFromStr("1.2"), + Alliance: AllianceDenom, + }, + { + Denom: "stake", + Index: sdk.MustNewDecFromStr("0.8"), + Alliance: AllianceDenomTwo, }, { - Denom: "stake2", - Index: sdk.MustNewDecFromStr("0.333333333333333333"), + Denom: "stake2", + Index: sdk.MustNewDecFromStr("0.8"), + Alliance: AllianceDenom, + }, + { + Denom: "stake2", + Index: sdk.MustNewDecFromStr("3.2"), + Alliance: AllianceDenomTwo, }, }), types.NewRewardHistories(val1.GlobalRewardHistory), @@ -210,33 +240,33 @@ func TestClaimRewards(t *testing.T) { // before claiming, there should be tokens in rewards pool coins := app.BankKeeper.GetAllBalances(ctx, rewardsPoolAddr) require.Equal(t, - sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(4000_000)), sdk.NewCoin("stake2", sdk.NewInt(4000_000))), + sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(2000_000)), sdk.NewCoin("stake2", sdk.NewInt(4000_000))), coins, ) // User 1 claims rewards - // User 1 has 1 STAKE (2 Power) - // Added 2 stake rewards (fully belonging to user 1) - // User 2 has 1 STAKE (10 Power) - // Added 2 stake rewards (user1: 2/12 * 2, user2: 10/12 * 2) - // Added 4 stake2 rewards (user1: 2/12 * 4, user2: 10/12 * 4) + // user 1 got full rewards for the first reward (stake) + // + 20% of the second deposit (stake) + // + 20% of the three deposits (stake2) coins, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val1, AllianceDenom) require.NoError(t, err) - require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(2_333_333)), sdk.NewCoin("stake2", sdk.NewInt(666_666))), coins) + require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(1_200_000)), sdk.NewCoin("stake2", sdk.NewInt(800_000))), coins) // User 2 claims rewards but doesn't use the right denom _, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val1, AllianceDenom) require.Error(t, err) // User 2 claims rewards + // user 2 got 80% of the second deposit (stake) + // + 80% of the three deposits (stake2) coins, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val1, AllianceDenomTwo) require.NoError(t, err) - require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(1_666_666)), sdk.NewCoin("stake2", sdk.NewInt(3_333_333))), coins) + require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(800_000)), sdk.NewCoin("stake2", sdk.NewInt(3_200_000))), coins) // After claiming, there should be nothing left in rewards pool // Some rounding left coins = app.BankKeeper.GetAllBalances(ctx, rewardsPoolAddr) - require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(1)), sdk.NewCoin("stake2", sdk.NewInt(1))), coins) + require.Equal(t, sdk.NewCoins(), coins) // Global indices require.NoError(t, err) @@ -245,11 +275,11 @@ func TestClaimRewards(t *testing.T) { // Check that all delegations have updated local indices delegation, found := app.AllianceKeeper.GetDelegation(ctx, user1, valAddr1, AllianceDenom) require.True(t, found) - require.Equal(t, indices, types.NewRewardHistories(delegation.RewardHistory)) + require.Equal(t, indices.GetIndexByAlliance(AllianceDenom), types.NewRewardHistories(delegation.RewardHistory)) delegation, found = app.AllianceKeeper.GetDelegation(ctx, user2, valAddr1, AllianceDenomTwo) require.True(t, found) - require.Equal(t, indices, types.NewRewardHistories(delegation.RewardHistory)) + require.Equal(t, indices.GetIndexByAlliance(AllianceDenomTwo), types.NewRewardHistories(delegation.RewardHistory)) } func TestClaimRewardsBeforeRewardsIssuance(t *testing.T) { @@ -259,7 +289,7 @@ func TestClaimRewardsBeforeRewardsIssuance(t *testing.T) { Params: types.DefaultParams(), Assets: []types.AllianceAsset{ types.NewAllianceAsset(AllianceDenom, sdk.NewDec(2), sdk.NewDec(0), sdk.NewDec(5), sdk.NewDec(0), ctx.BlockTime().Add(-time.Hour)), - types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(10), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime().Add(time.Hour)), + types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(8), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime().Add(time.Hour)), }, }) queryServer := keeper.NewQueryServerImpl(app.AllianceKeeper) @@ -369,7 +399,7 @@ func TestClaimRewardsWithMultipleValidators(t *testing.T) { Params: types.DefaultParams(), Assets: []types.AllianceAsset{ types.NewAllianceAsset(AllianceDenom, sdk.NewDec(2), sdk.NewDec(0), sdk.NewDec(5), sdk.NewDec(0), ctx.BlockTime()), - types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(10), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime()), + types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(8), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime()), }, }) @@ -383,7 +413,7 @@ func TestClaimRewardsWithMultipleValidators(t *testing.T) { // Accounts addrs := test_helpers.AddTestAddrsIncremental(app, ctx, 4, sdk.NewCoins( sdk.NewCoin(AllianceDenom, sdk.NewInt(1000_000)), - sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(1000_000)), + sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(10_000_000)), )) pks := test_helpers.CreateTestPubKeys(2) @@ -428,17 +458,17 @@ func TestClaimRewardsWithMultipleValidators(t *testing.T) { // New delegation from user 2 to val 2 val2, _ := app.AllianceKeeper.GetAllianceValidator(ctx, valAddr2) - _, err = app.AllianceKeeper.Delegate(ctx, user2, val2, sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(1000_000))) + _, err = app.AllianceKeeper.Delegate(ctx, user2, val2, sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(10_000_000))) require.NoError(t, err) assets := app.AllianceKeeper.GetAllAssets(ctx) err = app.AllianceKeeper.RebalanceBondTokenWeights(ctx, assets) require.NoError(t, err) // Check total bonded amount - require.Equal(t, sdk.NewInt(13_000_000), app.StakingKeeper.TotalBondedTokens(ctx)) + require.Equal(t, sdk.NewInt(11_000_000), app.StakingKeeper.TotalBondedTokens(ctx)) // Transfer to rewards to fee pool to be distributed - err = app.BankKeeper.SendCoinsFromModuleToModule(ctx, minttypes.ModuleName, authtypes.FeeCollectorName, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(4000_000)))) + err = app.BankKeeper.SendCoinsFromModuleToModule(ctx, minttypes.ModuleName, authtypes.FeeCollectorName, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(4_000_000)))) require.NoError(t, err) ctx = ctx.WithBlockHeight(ctx.BlockHeight() + 1) @@ -446,7 +476,7 @@ func TestClaimRewardsWithMultipleValidators(t *testing.T) { // At the next begin block, tokens will be distributed from the fee pool cons1, _ := val1.GetConsAddr() cons2, _ := val2.GetConsAddr() - var votingPower int64 = 12 + var votingPower int64 = 10 app.DistrKeeper.AllocateTokens(ctx, votingPower, []abcitypes.VoteInfo{ { Validator: abcitypes.Validator{ @@ -458,7 +488,7 @@ func TestClaimRewardsWithMultipleValidators(t *testing.T) { { Validator: abcitypes.Validator{ Address: cons2, - Power: 10, + Power: 8, }, SignedLastBlock: true, }, @@ -467,17 +497,17 @@ func TestClaimRewardsWithMultipleValidators(t *testing.T) { commission := app.DistrKeeper.GetValidatorAccumulatedCommission(ctx, val1.GetOperator()).Commission require.Equal(t, sdk.NewInt(0), commission.AmountOf("stake").TruncateInt()) commission = app.DistrKeeper.GetValidatorAccumulatedCommission(ctx, val2.GetOperator()).Commission - require.Equal(t, sdk.NewInt(3333333), commission.AmountOf("stake").TruncateInt()) + require.Equal(t, sdk.NewInt(3200_000), commission.AmountOf("stake").TruncateInt()) rewards := app.DistrKeeper.GetValidatorCurrentRewards(ctx, val1.GetOperator()).Rewards - require.Equal(t, sdk.NewInt(666666), rewards.AmountOf("stake").TruncateInt()) + require.Equal(t, sdk.NewInt(800_000), rewards.AmountOf("stake").TruncateInt()) rewards = app.DistrKeeper.GetValidatorCurrentRewards(ctx, val2.GetOperator()).Rewards require.Equal(t, sdk.NewInt(0), rewards.AmountOf("stake").TruncateInt()) // User 1 should be getting all the rewards from validator 1 since it has 0 commission coins, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val1, AllianceDenom) require.NoError(t, err) - require.Equal(t, sdk.NewInt(666666), coins.AmountOf("stake")) + require.Equal(t, sdk.NewInt(800_000), coins.AmountOf("stake")) // User 2 should be getting no rewards since validator 2 has 100% commission coins, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val2, AllianceDenomTwo) @@ -604,7 +634,8 @@ func TestClaimRewardsAfterRewardsRatesChange(t *testing.T) { PrevRewardWeight: sdk.NewDec(2), RewardHistories: val1.GlobalRewardHistory, }, snapshot) - iter.Close() + err = iter.Close() + require.NoError(t, err) // Accumulate rewards in pool err = app.BankKeeper.SendCoinsFromModuleToModule(ctx, minttypes.ModuleName, authtypes.FeeCollectorName, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(10_000_000)))) @@ -979,3 +1010,312 @@ func TestRewardWeightWithZeroTokens(t *testing.T) { require.Equal(t, beforeMintPoolAmount, afterMintPoolAmount) } + +func TestClaimRewardsWithDifferentTokenDecimals(t *testing.T) { + app, ctx := createTestContext(t) + app.AllianceKeeper.InitGenesis(ctx, &types.GenesisState{ + Params: types.DefaultParams(), + Assets: []types.AllianceAsset{ + types.NewAllianceAsset(AllianceDenom, sdk.NewDec(2), sdk.NewDec(0), sdk.NewDec(5), sdk.NewDec(0), ctx.BlockTime()), + types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(2), sdk.NewDec(0), sdk.NewDec(5), sdk.NewDec(0), ctx.BlockTime()), + }, + }) + + // Accounts + mintPoolAddr := app.AccountKeeper.GetModuleAddress(minttypes.ModuleName) + rewardsPoolAddr := app.AccountKeeper.GetModuleAddress(types.RewardsPoolName) + delegations := app.StakingKeeper.GetAllDelegations(ctx) + valAddr1, err := sdk.ValAddressFromBech32(delegations[0].ValidatorAddress) + require.NoError(t, err) + val1, err := app.AllianceKeeper.GetAllianceValidator(ctx, valAddr1) + require.NoError(t, err) + addrs := test_helpers.AddTestAddrsIncremental(app, ctx, 2, sdk.NewCoins( + sdk.NewCoin(AllianceDenom, sdk.NewInt(1000_000)), + sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(100_000_000)), + )) + user1 := addrs[0] + user2 := addrs[1] + + // Mint tokens + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(4000_000)))) + require.NoError(t, err) + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("stake2", sdk.NewInt(4000_000)))) + require.NoError(t, err) + + // New delegation from user 1 + _, err = app.AllianceKeeper.Delegate(ctx, user1, val1, sdk.NewCoin(AllianceDenom, sdk.NewInt(1000_000))) + require.NoError(t, err) + assets := app.AllianceKeeper.GetAllAssets(ctx) + err = app.AllianceKeeper.RebalanceBondTokenWeights(ctx, assets) + require.NoError(t, err) + + // New delegation from user 2 + _, err = app.AllianceKeeper.Delegate(ctx, user2, val1, sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(100_000_000))) + require.NoError(t, err) + assets = app.AllianceKeeper.GetAllAssets(ctx) + err = app.AllianceKeeper.RebalanceBondTokenWeights(ctx, assets) + require.NoError(t, err) + + // Transfer to reward pool + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(2000_000)))) + require.NoError(t, err) + + // User 1 claims rewards + coins, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val1, AllianceDenom) + require.NoError(t, err) + require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(1000_000))), coins) + + // User 2 claims rewards + coins, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val1, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(1000_000))), coins) + + // After claiming, there should be nothing left in rewards pool + // Some rounding left + coins = app.BankKeeper.GetAllBalances(ctx, rewardsPoolAddr) + require.Equal(t, sdk.NewCoins(sdk.NewCoin("stake", sdk.NewInt(0))), coins) +} + +// Since 0.3.4, rewards distribution logic has changed to be asset scoped +// this test makes sure that we have backward compatibility +func TestMigratedRewardsWithRatesChange(t *testing.T) { + var err error + app, ctx := createTestContext(t) + ctx = ctx.WithBlockHeight(1) + app.AllianceKeeper.InitGenesis(ctx, &types.GenesisState{ + Params: types.DefaultParams(), + Assets: []types.AllianceAsset{ + types.NewAllianceAsset(AllianceDenom, sdk.NewDec(2), sdk.NewDec(0), sdk.NewDec(5), sdk.NewDec(0), ctx.BlockTime()), + types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(8), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime()), + }, + }) + + // Set tax and rewards to be zero for easier calculation + distParams := app.DistrKeeper.GetParams(ctx) + distParams.CommunityTax = sdk.ZeroDec() + + err = app.DistrKeeper.SetParams(ctx, distParams) + require.NoError(t, err) + + // Accounts + mintPoolAddr := app.AccountKeeper.GetModuleAddress(minttypes.ModuleName) + bondDenom := app.StakingKeeper.BondDenom(ctx) + addrs := test_helpers.AddTestAddrsIncremental(app, ctx, 4, sdk.NewCoins( + sdk.NewCoin(AllianceDenom, sdk.NewInt(10_000_000)), + sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(10_000_000)), + )) + + // Creating validator 0% commissions + pks := test_helpers.CreateTestPubKeys(2) + valAddr1 := sdk.ValAddress(addrs[0]) + _val1 := teststaking.NewValidator(t, valAddr1, pks[0]) + _val1.Commission = stakingtypes.Commission{ + CommissionRates: stakingtypes.CommissionRates{ + Rate: sdk.NewDec(0), + MaxRate: sdk.NewDec(0), + MaxChangeRate: sdk.NewDec(0), + }, + UpdateTime: time.Now(), + } + test_helpers.RegisterNewValidator(t, app, ctx, _val1) + val1, err := app.AllianceKeeper.GetAllianceValidator(ctx, valAddr1) + require.NoError(t, err) + + user1 := addrs[2] + user2 := addrs[3] + + // Mint bond denom + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(40_000_000)))) + require.NoError(t, err) + + // New delegations + _, err = app.AllianceKeeper.Delegate(ctx, user1, val1, sdk.NewCoin(AllianceDenom, sdk.NewInt(1_000_000))) + require.NoError(t, err) + _, err = app.AllianceKeeper.Delegate(ctx, user2, val1, sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(1_000_000))) + require.NoError(t, err) + + assets := app.AllianceKeeper.GetAllAssets(ctx) + err = app.AllianceKeeper.RebalanceBondTokenWeights(ctx, assets) + require.NoError(t, err) + + // Manually update global asset history + val1.GlobalRewardHistory = append(val1.GlobalRewardHistory, types.RewardHistory{ + Denom: bondDenom, + Index: sdk.MustNewDecFromStr("0.5"), + Alliance: "", + }) + app.AllianceKeeper.SetValidator(ctx, val1) + err = app.BankKeeper.SendCoinsFromModuleToModule(ctx, minttypes.ModuleName, types.RewardsPoolName, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(5_000_000)))) + require.NoError(t, err) + + // Check rewards for user1 + queryServer := keeper.NewQueryServerImpl(app.AllianceKeeper) + qCtx, _ := ctx.CacheContext() + rewards, err := queryServer.AllianceDelegationRewards(qCtx, &types.QueryAllianceDelegationRewardsRequest{ + DelegatorAddr: user1.String(), + ValidatorAddr: val1.GetOperator().String(), + Denom: AllianceDenom, + Pagination: nil, + }) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(1_000_000), sdk.NewCoins(rewards.Rewards...).AmountOf(bondDenom)) + + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(10_000_000)))) + require.NoError(t, err) + + // Update alliance asset reward weight + err = app.AllianceKeeper.UpdateAllianceAsset(ctx, types.NewAllianceAsset(AllianceDenom, sdk.NewDec(8), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime())) + require.NoError(t, err) + assets = app.AllianceKeeper.GetAllAssets(ctx) + err = app.AllianceKeeper.RebalanceBondTokenWeights(ctx, assets) + require.NoError(t, err) + + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(10_000_000)))) + require.NoError(t, err) + + rewards1, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val1, AllianceDenom) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(1_000_000+2_000_000+5_000_000), rewards1.AmountOf(bondDenom)) + + rewards2, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val1, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(4_000_000+8_000_000+5_000_000), rewards2.AmountOf(bondDenom)) +} + +func TestMigratedRewards(t *testing.T) { + var err error + app, ctx := createTestContext(t) + ctx = ctx.WithBlockHeight(1) + app.AllianceKeeper.InitGenesis(ctx, &types.GenesisState{ + Params: types.DefaultParams(), + Assets: []types.AllianceAsset{ + types.NewAllianceAsset(AllianceDenom, sdk.NewDec(2), sdk.NewDec(0), sdk.NewDec(5), sdk.NewDec(0), ctx.BlockTime()), + types.NewAllianceAsset(AllianceDenomTwo, sdk.NewDec(8), sdk.NewDec(2), sdk.NewDec(12), sdk.NewDec(0), ctx.BlockTime()), + }, + }) + + // Set tax and rewards to be zero for easier calculation + distParams := app.DistrKeeper.GetParams(ctx) + distParams.CommunityTax = sdk.ZeroDec() + + err = app.DistrKeeper.SetParams(ctx, distParams) + require.NoError(t, err) + + // Accounts + mintPoolAddr := app.AccountKeeper.GetModuleAddress(minttypes.ModuleName) + bondDenom := app.StakingKeeper.BondDenom(ctx) + addrs := test_helpers.AddTestAddrsIncremental(app, ctx, 4, sdk.NewCoins( + sdk.NewCoin(AllianceDenom, sdk.NewInt(10_000_000)), + sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(10_000_000)), + )) + + pks := test_helpers.CreateTestPubKeys(2) + + // Creating two validators with 0% commission + valAddr1 := sdk.ValAddress(addrs[0]) + _val1 := teststaking.NewValidator(t, valAddr1, pks[0]) + _val1.Commission = stakingtypes.Commission{ + CommissionRates: stakingtypes.CommissionRates{ + Rate: sdk.NewDec(0), + MaxRate: sdk.NewDec(0), + MaxChangeRate: sdk.NewDec(0), + }, + UpdateTime: time.Now(), + } + test_helpers.RegisterNewValidator(t, app, ctx, _val1) + + valAddr2 := sdk.ValAddress(addrs[1]) + _val2 := teststaking.NewValidator(t, valAddr2, pks[1]) + _val2.Commission = stakingtypes.Commission{ + CommissionRates: stakingtypes.CommissionRates{ + Rate: sdk.NewDec(0), + MaxRate: sdk.NewDec(0), + MaxChangeRate: sdk.NewDec(0), + }, + UpdateTime: time.Now(), + } + test_helpers.RegisterNewValidator(t, app, ctx, _val2) + + val1, _ := app.AllianceKeeper.GetAllianceValidator(ctx, valAddr1) + val2, _ := app.AllianceKeeper.GetAllianceValidator(ctx, valAddr2) + + user1 := addrs[2] + user2 := addrs[3] + + // Mint bond denom + err = app.BankKeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(40_000_000)))) + require.NoError(t, err) + + // New delegations + _, err = app.AllianceKeeper.Delegate(ctx, user1, val1, sdk.NewCoin(AllianceDenom, sdk.NewInt(1000_000))) + require.NoError(t, err) + _, err = app.AllianceKeeper.Delegate(ctx, user2, val1, sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(1000_000))) + require.NoError(t, err) + _, err = app.AllianceKeeper.Delegate(ctx, user1, val2, sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(1000_000))) + require.NoError(t, err) + _, err = app.AllianceKeeper.Delegate(ctx, user2, val2, sdk.NewCoin(AllianceDenomTwo, sdk.NewInt(1000_000))) + require.NoError(t, err) + + assets := app.AllianceKeeper.GetAllAssets(ctx) + err = app.AllianceKeeper.RebalanceBondTokenWeights(ctx, assets) + require.NoError(t, err) + + // Manually update global asset history + val1.GlobalRewardHistory = append(val1.GlobalRewardHistory, + types.RewardHistory{ + Denom: bondDenom, + Index: sdk.MustNewDecFromStr("0.5"), + Alliance: "", + }, + ) + app.AllianceKeeper.SetValidator(ctx, val1) + + val2.GlobalRewardHistory = append(val2.GlobalRewardHistory, + types.RewardHistory{ + Denom: bondDenom, + Index: sdk.MustNewDecFromStr("0.5"), + Alliance: "", + }, + ) + app.AllianceKeeper.SetValidator(ctx, val2) + err = app.BankKeeper.SendCoinsFromModuleToModule(ctx, minttypes.ModuleName, types.RewardsPoolName, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(13_000_000)))) + require.NoError(t, err) + + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val1, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(10_000_000)))) + require.NoError(t, err) + err = app.AllianceKeeper.AddAssetsToRewardPool(ctx, mintPoolAddr, val2, sdk.NewCoins(sdk.NewCoin(bondDenom, sdk.NewInt(10_000_000)))) + require.NoError(t, err) + + rewards1, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val1, AllianceDenom) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(1_000_000+2_000_000), rewards1.AmountOf(bondDenom)) + + rewards2, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val1, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(4_000_000+8_000_000), rewards2.AmountOf(bondDenom)) + + rewards3, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val2, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(4_000_000+5_000_000-1), rewards3.AmountOf(bondDenom)) + + rewards4, err := app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val2, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(4_000_000+5_000_000-1), rewards4.AmountOf(bondDenom)) + + // Make sure nothing left to claim + rewards1, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val1, AllianceDenom) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(0), rewards1.AmountOf(bondDenom)) + + rewards2, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val1, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(0), rewards2.AmountOf(bondDenom)) + + rewards3, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user1, val2, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(0), rewards3.AmountOf(bondDenom)) + + rewards4, err = app.AllianceKeeper.ClaimDelegationRewards(ctx, user2, val2, AllianceDenomTwo) + require.NoError(t, err) + require.Equal(t, sdk.NewInt(0), rewards4.AmountOf(bondDenom)) +} diff --git a/x/alliance/types/alliance.go b/x/alliance/types/alliance.go index f5db14b..edcc2be 100644 --- a/x/alliance/types/alliance.go +++ b/x/alliance/types/alliance.go @@ -1,8 +1,9 @@ package types func NewRewardWeightChangeSnapshot(asset AllianceAsset, val AllianceValidator) RewardWeightChangeSnapshot { + assetRewardHistory := RewardHistories(val.GlobalRewardHistory).GetIndexByAlliance(asset.Denom) return RewardWeightChangeSnapshot{ PrevRewardWeight: asset.RewardWeight, - RewardHistories: val.GlobalRewardHistory, + RewardHistories: assetRewardHistory, } } diff --git a/x/alliance/types/params.go b/x/alliance/types/params.go index 34faa56..c9f74de 100644 --- a/x/alliance/types/params.go +++ b/x/alliance/types/params.go @@ -70,9 +70,20 @@ func NewRewardHistories(r []RewardHistory) RewardHistories { return r } -func (r RewardHistories) GetIndexByDenom(denom string) (ri *RewardHistory, found bool) { +func (r RewardHistories) GetIndexByAlliance(alliance string) (ris RewardHistories) { + for _, rh := range r { + // If alliance is empty, it means it was the legacy reward history that does not have a specific alliance + // Used to handle the old implementation of reward history + if rh.Alliance == alliance || rh.Alliance == "" { + ris = append(ris, rh) + } + } + return ris +} + +func (r RewardHistories) GetIndexByDenom(denom string, alliance string) (ri *RewardHistory, found bool) { idx := slices.IndexFunc(r, func(e RewardHistory) bool { - return e.Denom == denom + return e.Denom == denom && e.Alliance == alliance }) if idx < 0 { return &RewardHistory{}, false diff --git a/x/alliance/types/params.pb.go b/x/alliance/types/params.pb.go index 3aafaf5..af63da3 100644 --- a/x/alliance/types/params.pb.go +++ b/x/alliance/types/params.pb.go @@ -93,8 +93,9 @@ func (m *Params) GetLastTakeRateClaimTime() time.Time { } type RewardHistory struct { - Denom string `protobuf:"bytes,1,opt,name=denom,proto3" json:"denom,omitempty"` - Index github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=index,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"index"` + Denom string `protobuf:"bytes,1,opt,name=denom,proto3" json:"denom,omitempty"` + Index github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=index,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"index"` + Alliance string `protobuf:"bytes,3,opt,name=alliance,proto3" json:"alliance,omitempty"` } func (m *RewardHistory) Reset() { *m = RewardHistory{} } @@ -137,6 +138,13 @@ func (m *RewardHistory) GetDenom() string { return "" } +func (m *RewardHistory) GetAlliance() string { + if m != nil { + return m.Alliance + } + return "" +} + func init() { proto.RegisterType((*Params)(nil), "alliance.alliance.Params") proto.RegisterType((*RewardHistory)(nil), "alliance.alliance.RewardHistory") @@ -145,33 +153,34 @@ func init() { func init() { proto.RegisterFile("alliance/alliance/params.proto", fileDescriptor_245e75f0d2ae44fd) } var fileDescriptor_245e75f0d2ae44fd = []byte{ - // 413 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0xb1, 0xce, 0xd3, 0x30, - 0x10, 0xc7, 0x93, 0x0f, 0xbe, 0x8a, 0x1a, 0x21, 0xd4, 0xa8, 0x48, 0x6d, 0x07, 0x07, 0x75, 0x40, - 0x2c, 0x4d, 0x10, 0x6c, 0x88, 0xa9, 0x64, 0x00, 0x16, 0x50, 0xd4, 0x09, 0x21, 0x22, 0x37, 0x39, - 0x82, 0xd5, 0x38, 0x8e, 0x6c, 0x17, 0x9a, 0x89, 0x57, 0xe8, 0xc8, 0x82, 0xc4, 0x43, 0xf0, 0x10, - 0x1d, 0x2b, 0x26, 0xc4, 0x50, 0x50, 0xbb, 0xf0, 0x18, 0xc8, 0x76, 0x42, 0xab, 0xb2, 0x7c, 0x53, - 0xee, 0xf2, 0x3f, 0xff, 0xfe, 0x77, 0x3e, 0x23, 0x4c, 0x8a, 0x82, 0x92, 0x32, 0x85, 0xf0, 0x5f, - 0x50, 0x11, 0x41, 0x98, 0x0c, 0x2a, 0xc1, 0x15, 0xf7, 0x7a, 0xed, 0xef, 0xa0, 0x0d, 0x46, 0xfd, - 0x9c, 0xe7, 0xdc, 0xa8, 0xa1, 0x8e, 0x6c, 0xe1, 0x68, 0x98, 0x72, 0xc9, 0xb8, 0x4c, 0xac, 0x60, - 0x93, 0x46, 0xc2, 0x39, 0xe7, 0x79, 0x01, 0xa1, 0xc9, 0xe6, 0xcb, 0x77, 0x61, 0xb6, 0x14, 0x44, - 0x51, 0x5e, 0x36, 0xba, 0x7f, 0xae, 0x2b, 0xca, 0x40, 0x2a, 0xc2, 0x2a, 0x5b, 0x30, 0xfe, 0x72, - 0x81, 0x3a, 0xaf, 0x4c, 0x57, 0xde, 0x4b, 0xd4, 0x13, 0xf0, 0x91, 0x88, 0x2c, 0xc9, 0xa0, 0x20, - 0x75, 0xa2, 0x4b, 0x07, 0xee, 0x5d, 0xf7, 0xfe, 0xcd, 0x87, 0xc3, 0xc0, 0x72, 0x82, 0x96, 0x13, - 0x44, 0x8d, 0xcf, 0xf4, 0xc6, 0x66, 0xe7, 0x3b, 0x9f, 0x7f, 0xf9, 0x6e, 0x7c, 0xdb, 0x9e, 0x8e, - 0xf4, 0xe1, 0x19, 0x65, 0xe0, 0xbd, 0x41, 0x03, 0x45, 0x16, 0x90, 0x08, 0xa2, 0x20, 0x49, 0x0b, - 0x42, 0x59, 0x42, 0x4b, 0x05, 0xe2, 0x03, 0x29, 0x06, 0x17, 0x57, 0xe7, 0xde, 0xd1, 0x90, 0x98, - 0x28, 0x78, 0xaa, 0x11, 0xcf, 0x1b, 0x82, 0xf7, 0x16, 0x0d, 0x0b, 0x22, 0x55, 0x72, 0x6e, 0x61, - 0xda, 0xbe, 0x66, 0xf0, 0xa3, 0xff, 0xf0, 0xb3, 0x76, 0x7c, 0xcb, 0x5f, 0x1b, 0xbe, 0xc6, 0xcc, - 0x4e, 0x3d, 0x74, 0xd5, 0xe3, 0xeb, 0x7f, 0xbe, 0xfa, 0xee, 0xf8, 0x13, 0xba, 0x15, 0x9b, 0xb1, - 0x9e, 0x51, 0xa9, 0xb8, 0xa8, 0xbd, 0x3e, 0xba, 0xcc, 0xa0, 0xe4, 0xcc, 0xdc, 0x4c, 0x37, 0xb6, - 0x89, 0x17, 0xa3, 0x4b, 0x5a, 0x66, 0xb0, 0x32, 0x73, 0x75, 0xa7, 0x4f, 0x34, 0xfc, 0xe7, 0xce, - 0xbf, 0x97, 0x53, 0xf5, 0x7e, 0x39, 0x0f, 0x52, 0xce, 0x9a, 0xbd, 0x35, 0x9f, 0x89, 0xcc, 0x16, - 0xa1, 0xaa, 0x2b, 0x90, 0x41, 0x04, 0xe9, 0xf7, 0x6f, 0x13, 0xd4, 0xac, 0x35, 0x82, 0x34, 0xb6, - 0x28, 0xdb, 0xc0, 0xf4, 0xc5, 0x66, 0x8f, 0xdd, 0xed, 0x1e, 0xbb, 0xbf, 0xf7, 0xd8, 0x5d, 0x1f, - 0xb0, 0xb3, 0x3d, 0x60, 0xe7, 0xc7, 0x01, 0x3b, 0xaf, 0x1f, 0x9c, 0xc0, 0x15, 0x08, 0x41, 0x26, - 0x8c, 0x97, 0x50, 0x1f, 0x5f, 0xdb, 0xea, 0x18, 0x1a, 0xab, 0x79, 0xc7, 0xdc, 0xc3, 0xa3, 0xbf, - 0x01, 0x00, 0x00, 0xff, 0xff, 0x74, 0x17, 0x53, 0xfa, 0x9a, 0x02, 0x00, 0x00, + // 426 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0x31, 0x8f, 0xd3, 0x30, + 0x14, 0xc7, 0xe3, 0x83, 0x3b, 0x5d, 0x8d, 0x10, 0xba, 0xe8, 0x90, 0xda, 0x0c, 0x0e, 0xba, 0x01, + 0xb1, 0x34, 0x41, 0xb0, 0x21, 0xa6, 0x92, 0x01, 0x58, 0x40, 0x51, 0x27, 0x84, 0x88, 0xdc, 0xe4, + 0x11, 0xac, 0x8b, 0xe3, 0xc8, 0x76, 0xe1, 0xf2, 0x2d, 0x6e, 0x44, 0x42, 0x48, 0x7c, 0x08, 0x3e, + 0xc4, 0x8d, 0x15, 0x13, 0x62, 0x28, 0xa8, 0x5d, 0xf8, 0x18, 0xc8, 0x76, 0xd2, 0x56, 0x65, 0xb9, + 0x29, 0xef, 0xe5, 0xff, 0xfc, 0x7b, 0xef, 0x6f, 0x3f, 0x4c, 0x68, 0x55, 0x31, 0x5a, 0xe7, 0x10, + 0x6f, 0x82, 0x86, 0x4a, 0xca, 0x55, 0xd4, 0x48, 0xa1, 0x85, 0x7f, 0xd2, 0xff, 0x8e, 0xfa, 0x20, + 0x38, 0x2d, 0x45, 0x29, 0xac, 0x1a, 0x9b, 0xc8, 0x15, 0x06, 0xa3, 0x5c, 0x28, 0x2e, 0x54, 0xe6, + 0x04, 0x97, 0x74, 0x12, 0x29, 0x85, 0x28, 0x2b, 0x88, 0x6d, 0x36, 0x9b, 0xbf, 0x8f, 0x8b, 0xb9, + 0xa4, 0x9a, 0x89, 0xba, 0xd3, 0xc3, 0x7d, 0x5d, 0x33, 0x0e, 0x4a, 0x53, 0xde, 0xb8, 0x82, 0xb3, + 0xaf, 0x07, 0xf8, 0xe8, 0xb5, 0x9d, 0xca, 0x7f, 0x85, 0x4f, 0x24, 0x7c, 0xa2, 0xb2, 0xc8, 0x0a, + 0xa8, 0x68, 0x9b, 0x99, 0xd2, 0x21, 0xba, 0x87, 0x1e, 0xdc, 0x7a, 0x34, 0x8a, 0x1c, 0x27, 0xea, + 0x39, 0x51, 0xd2, 0xf5, 0x99, 0x1c, 0x5f, 0x2d, 0x43, 0xef, 0xf3, 0xef, 0x10, 0xa5, 0x77, 0xdc, + 0xe9, 0xc4, 0x1c, 0x9e, 0x32, 0x0e, 0xfe, 0x5b, 0x3c, 0xd4, 0xf4, 0x1c, 0x32, 0x49, 0x35, 0x64, + 0x79, 0x45, 0x19, 0xcf, 0x58, 0xad, 0x41, 0x7e, 0xa4, 0xd5, 0xf0, 0xe0, 0xfa, 0xdc, 0xbb, 0x06, + 0x92, 0x52, 0x0d, 0xcf, 0x0c, 0xe2, 0x45, 0x47, 0xf0, 0xdf, 0xe1, 0x51, 0x45, 0x95, 0xce, 0xf6, + 0x5b, 0xd8, 0xb1, 0x6f, 0x58, 0x7c, 0xf0, 0x1f, 0x7e, 0xda, 0xdb, 0x77, 0xfc, 0x4b, 0xcb, 0x37, + 0x98, 0xe9, 0x6e, 0x0f, 0x53, 0xf5, 0xe4, 0xe6, 0xdf, 0x6f, 0x21, 0x3a, 0xfb, 0x82, 0xf0, 0xed, + 0xd4, 0xfa, 0x7a, 0xce, 0x94, 0x16, 0xb2, 0xf5, 0x4f, 0xf1, 0x61, 0x01, 0xb5, 0xe0, 0xf6, 0x6a, + 0x06, 0xa9, 0x4b, 0xfc, 0x14, 0x1f, 0xb2, 0xba, 0x80, 0x0b, 0x6b, 0x6c, 0x30, 0x79, 0x6a, 0xe8, + 0xbf, 0x96, 0xe1, 0xfd, 0x92, 0xe9, 0x0f, 0xf3, 0x59, 0x94, 0x0b, 0xde, 0x3d, 0x5c, 0xf7, 0x19, + 0xab, 0xe2, 0x3c, 0xd6, 0x6d, 0x03, 0x2a, 0x4a, 0x20, 0xff, 0xf1, 0x7d, 0x8c, 0xbb, 0x77, 0x4d, + 0x20, 0x4f, 0x1d, 0xca, 0x0f, 0xf0, 0x71, 0xbf, 0x19, 0xd6, 0xd0, 0x20, 0xdd, 0xe4, 0x6e, 0xba, + 0xc9, 0xcb, 0xab, 0x15, 0x41, 0x8b, 0x15, 0x41, 0x7f, 0x56, 0x04, 0x5d, 0xae, 0x89, 0xb7, 0x58, + 0x13, 0xef, 0xe7, 0x9a, 0x78, 0x6f, 0x1e, 0xee, 0x34, 0xd6, 0x20, 0x25, 0x1d, 0x73, 0x51, 0x43, + 0xbb, 0x5d, 0xc5, 0x8b, 0x6d, 0x68, 0xc7, 0x98, 0x1d, 0xd9, 0x4b, 0x7a, 0xfc, 0x2f, 0x00, 0x00, + 0xff, 0xff, 0x61, 0xb2, 0x67, 0xb7, 0xb7, 0x02, 0x00, 0x00, } func (this *Params) Equal(that interface{}) bool { @@ -229,6 +238,9 @@ func (this *RewardHistory) Equal(that interface{}) bool { if !this.Index.Equal(that1.Index) { return false } + if this.Alliance != that1.Alliance { + return false + } return true } func (m *Params) Marshal() (dAtA []byte, err error) { @@ -298,6 +310,13 @@ func (m *RewardHistory) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + if len(m.Alliance) > 0 { + i -= len(m.Alliance) + copy(dAtA[i:], m.Alliance) + i = encodeVarintParams(dAtA, i, uint64(len(m.Alliance))) + i-- + dAtA[i] = 0x1a + } { size := m.Index.Size() i -= size @@ -356,6 +375,10 @@ func (m *RewardHistory) Size() (n int) { } l = m.Index.Size() n += 1 + l + sovParams(uint64(l)) + l = len(m.Alliance) + if l > 0 { + n += 1 + l + sovParams(uint64(l)) + } return n } @@ -609,6 +632,38 @@ func (m *RewardHistory) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Alliance", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowParams + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthParams + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthParams + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Alliance = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipParams(dAtA[iNdEx:])