-
Notifications
You must be signed in to change notification settings - Fork 3.8k
/
Copy pathpool.go
113 lines (91 loc) · 3.34 KB
/
pool.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
package keeper
import (
"context"
"cosmossdk.io/math"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/x/staking/types"
)
// GetBondedPool returns the bonded tokens pool's module account
func (k Keeper) GetBondedPool(ctx context.Context) (bondedPool sdk.ModuleAccountI) {
return k.authKeeper.GetModuleAccount(ctx, types.BondedPoolName)
}
// GetNotBondedPool returns the not bonded tokens pool's module account
func (k Keeper) GetNotBondedPool(ctx context.Context) (notBondedPool sdk.ModuleAccountI) {
return k.authKeeper.GetModuleAccount(ctx, types.NotBondedPoolName)
}
// bondedTokensToNotBonded transfers coins from the bonded to the not bonded pool within staking
func (k Keeper) bondedTokensToNotBonded(ctx context.Context, tokens math.Int) error {
bondDenom, err := k.BondDenom(ctx)
if err != nil {
return err
}
coins := sdk.NewCoins(sdk.NewCoin(bondDenom, tokens))
return k.bankKeeper.SendCoinsFromModuleToModule(ctx, types.BondedPoolName, types.NotBondedPoolName, coins)
}
// notBondedTokensToBonded transfers coins from the not bonded to the bonded pool within staking
func (k Keeper) notBondedTokensToBonded(ctx context.Context, tokens math.Int) error {
bondDenom, err := k.BondDenom(ctx)
if err != nil {
return err
}
coins := sdk.NewCoins(sdk.NewCoin(bondDenom, tokens))
return k.bankKeeper.SendCoinsFromModuleToModule(ctx, types.NotBondedPoolName, types.BondedPoolName, coins)
}
// burnBondedTokens burns coins from the bonded pool module account
func (k Keeper) burnBondedTokens(ctx context.Context, amt math.Int) error {
if !amt.IsPositive() {
// skip as no coins need to be burned
return nil
}
bondDenom, err := k.BondDenom(ctx)
if err != nil {
return err
}
coins := sdk.NewCoins(sdk.NewCoin(bondDenom, amt))
return k.bankKeeper.BurnCoins(ctx, types.BondedPoolName, coins)
}
// burnNotBondedTokens burns coins from the not bonded pool module account
func (k Keeper) burnNotBondedTokens(ctx context.Context, amt math.Int) error {
if !amt.IsPositive() {
// skip as no coins need to be burned
return nil
}
bondDenom, err := k.BondDenom(ctx)
if err != nil {
return err
}
coins := sdk.NewCoins(sdk.NewCoin(bondDenom, amt))
return k.bankKeeper.BurnCoins(ctx, types.NotBondedPoolName, coins)
}
// TotalBondedTokens total staking tokens supply which is bonded
func (k Keeper) TotalBondedTokens(ctx context.Context) (math.Int, error) {
bondedPool := k.GetBondedPool(ctx)
bondDenom, err := k.BondDenom(ctx)
if err != nil {
return math.ZeroInt(), err
}
return k.bankKeeper.GetBalance(ctx, bondedPool.GetAddress(), bondDenom).Amount, nil
}
// StakingTokenSupply staking tokens from the total supply
func (k Keeper) StakingTokenSupply(ctx context.Context) (math.Int, error) {
bondDenom, err := k.BondDenom(ctx)
if err != nil {
return math.ZeroInt(), err
}
return k.bankKeeper.GetSupply(ctx, bondDenom).Amount, nil
}
// BondedRatio the fraction of the staking tokens which are currently bonded
func (k Keeper) BondedRatio(ctx context.Context) (math.LegacyDec, error) {
stakeSupply, err := k.StakingTokenSupply(ctx)
if err != nil {
return math.LegacyZeroDec(), err
}
if stakeSupply.IsPositive() {
totalBonded, err := k.TotalBondedTokens(ctx)
if err != nil {
return math.LegacyZeroDec(), err
}
return math.LegacyNewDecFromInt(totalBonded).QuoInt(stakeSupply), nil
}
return math.LegacyZeroDec(), nil
}