mirror of
https://github.com/0glabs/0g-chain.git
synced 2024-12-27 16:55:21 +00:00
142 lines
6.1 KiB
Markdown
142 lines
6.1 KiB
Markdown
<!--
|
|
order: 2
|
|
-->
|
|
|
|
# State
|
|
|
|
## Parameters and Genesis State
|
|
|
|
`Parameters` define the types of incentives that are available and the rewards that are available for each incentive.
|
|
|
|
```go
|
|
// Params governance parameters for the incentive module
|
|
type Params struct {
|
|
USDXMintingRewardPeriods RewardPeriods `json:"usdx_minting_reward_periods" yaml:"usdx_minting_reward_periods"`
|
|
HardSupplyRewardPeriods MultiRewardPeriods `json:"hard_supply_reward_periods" yaml:"hard_supply_reward_periods"`
|
|
HardBorrowRewardPeriods MultiRewardPeriods `json:"hard_borrow_reward_periods" yaml:"hard_borrow_reward_periods"`
|
|
DelegatorRewardPeriods MultiRewardPeriods `json:"delegator_reward_periods" yaml:"delegator_reward_periods"`
|
|
SwapRewardPeriods MultiRewardPeriods `json:"swap_reward_periods" yaml:"swap_reward_periods"`
|
|
ClaimMultipliers Multipliers `json:"claim_multipliers" yaml:"claim_multipliers"`
|
|
ClaimEnd time.Time `json:"claim_end" yaml:"claim_end"`
|
|
}
|
|
|
|
```
|
|
|
|
Each `RewardPeriod` defines a particular collateral for which rewards are eligible and the amount of rewards available.
|
|
|
|
```go
|
|
// RewardPeriod stores the state of an ongoing reward
|
|
type RewardPeriod struct {
|
|
Active bool `json:"active" yaml:"active"` // if the reward is active
|
|
CollateralType string `json:"collateral_type" yaml:"collateral_type"` // the collateral type for which rewards apply
|
|
Start time.Time `json:"start" yaml:"start"` // when the rewards start
|
|
End time.Time `json:"end" yaml:"end"` // when the rewards end
|
|
RewardsPerSecond sdk.Coin `json:"rewards_per_second" yaml:"rewards_per_second"` // per second reward payouts
|
|
}
|
|
```
|
|
|
|
Each `MultiRewardPeriod` defines a particular collateral for which one or more reward tokens are eligible and the amount of rewards available
|
|
|
|
```go
|
|
// MultiRewardPeriod supports multiple reward types
|
|
type MultiRewardPeriod struct {
|
|
Active bool `json:"active" yaml:"active"`
|
|
CollateralType string `json:"collateral_type" yaml:"collateral_type"`
|
|
Start time.Time `json:"start" yaml:"start"`
|
|
End time.Time `json:"end" yaml:"end"`
|
|
RewardsPerSecond sdk.Coins `json:"rewards_per_second" yaml:"rewards_per_second"` // per second reward payouts
|
|
}
|
|
```
|
|
|
|
`GenesisState` defines the state that must be persisted when the blockchain stops/restarts in order for normal function of the incentive module to resume.
|
|
|
|
```go
|
|
// GenesisState is the state that must be provided at genesis.
|
|
type GenesisState struct {
|
|
Params Params `json:"params" yaml:"params"`
|
|
|
|
USDXRewardState GenesisRewardState `json:"usdx_reward_state" yaml:"usdx_reward_state"`
|
|
HardSupplyRewardState GenesisRewardState `json:"hard_supply_reward_state" yaml:"hard_supply_reward_state"`
|
|
HardBorrowRewardState GenesisRewardState `json:"hard_borrow_reward_state" yaml:"hard_borrow_reward_state"`
|
|
DelegatorRewardState GenesisRewardState `json:"delegator_reward_state" yaml:"delegator_reward_state"`
|
|
SwapRewardState GenesisRewardState `json:"swap_reward_state" yaml:"swap_reward_state"`
|
|
|
|
USDXMintingClaims USDXMintingClaims `json:"usdx_minting_claims" yaml:"usdx_minting_claims"`
|
|
HardLiquidityProviderClaims HardLiquidityProviderClaims `json:"hard_liquidity_provider_claims" yaml:"hard_liquidity_provider_claims"`
|
|
DelegatorClaims DelegatorClaims `json:"delegator_claims" yaml:"delegator_claims"`
|
|
SwapClaims SwapClaims `json:"swap_claims" yaml:"swap_claims"`
|
|
}
|
|
```
|
|
|
|
## Store
|
|
|
|
For complete details for how items are stored, see [keys.go](../types/keys.go).
|
|
|
|
### Claim Creation
|
|
|
|
When users take incentivized actions, the `incentive` module will create or update a `Claim` object in the store, which represents the amount of rewards that the user is eligible to claim. Each `Claim` object contains one or several RewardIndexes, which are used to calculate the amount of rewards a user can claim. There are four defined claim objects:
|
|
|
|
- `USDXMintingClaim`
|
|
- `HardLiquidityProviderClaim`
|
|
- `DelegatorClaim`
|
|
- `SwapClaim`
|
|
|
|
```go
|
|
|
|
// Claim is an interface for handling common claim actions
|
|
type Claim interface {
|
|
GetOwner() sdk.AccAddress
|
|
GetReward() sdk.Coin
|
|
GetType() string
|
|
}
|
|
|
|
// BaseClaim is a common type shared by all Claims
|
|
type BaseClaim struct {
|
|
Owner sdk.AccAddress `json:"owner" yaml:"owner"`
|
|
Reward sdk.Coin `json:"reward" yaml:"reward"`
|
|
}
|
|
|
|
// BaseMultiClaim is a common type shared by all Claims with multiple reward denoms
|
|
type BaseMultiClaim struct {
|
|
Owner sdk.AccAddress `json:"owner" yaml:"owner"`
|
|
Reward sdk.Coins `json:"reward" yaml:"reward"`
|
|
}
|
|
|
|
// RewardIndex stores reward accumulation information
|
|
type RewardIndex struct {
|
|
CollateralType string `json:"collateral_type" yaml:"collateral_type"`
|
|
RewardFactor sdk.Dec `json:"reward_factor" yaml:"reward_factor"`
|
|
}
|
|
|
|
// MultiRewardIndex stores reward accumulation information on multiple reward types
|
|
type MultiRewardIndex struct {
|
|
CollateralType string `json:"collateral_type" yaml:"collateral_type"`
|
|
RewardIndexes RewardIndexes `json:"reward_indexes" yaml:"reward_indexes"`
|
|
}
|
|
|
|
// USDXMintingClaim is for USDX minting rewards
|
|
type USDXMintingClaim struct {
|
|
BaseClaim `json:"base_claim" yaml:"base_claim"`
|
|
RewardIndexes RewardIndexes `json:"reward_indexes" yaml:"reward_indexes"`
|
|
}
|
|
|
|
// HardLiquidityProviderClaim stores the hard liquidity provider rewards that can be claimed by owner
|
|
type HardLiquidityProviderClaim struct {
|
|
BaseMultiClaim `json:"base_claim" yaml:"base_claim"`
|
|
SupplyRewardIndexes MultiRewardIndexes `json:"supply_reward_indexes" yaml:"supply_reward_indexes"`
|
|
BorrowRewardIndexes MultiRewardIndexes `json:"borrow_reward_indexes" yaml:"borrow_reward_indexes"`
|
|
}
|
|
|
|
// DelegatorClaim stores delegation rewards that can be claimed by owner
|
|
type DelegatorClaim struct {
|
|
BaseMultiClaim `json:"base_claim" yaml:"base_claim"`
|
|
RewardIndexes MultiRewardIndexes `json:"reward_indexes" yaml:"reward_indexes"`
|
|
}
|
|
|
|
// SwapClaim stores the swap rewards that can be claimed by owner
|
|
type SwapClaim struct {
|
|
BaseMultiClaim `json:"base_claim" yaml:"base_claim"`
|
|
RewardIndexes MultiRewardIndexes `json:"reward_indexes" yaml:"reward_indexes"`
|
|
}
|
|
```
|