-
-
Notifications
You must be signed in to change notification settings - Fork 14
/
params.go
118 lines (96 loc) · 2.76 KB
/
params.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
114
115
116
117
118
package types
import (
"fmt"
"time"
sdk "github.com/cosmos/cosmos-sdk/types"
paramstype "github.com/cosmos/cosmos-sdk/x/params/types"
tmtime "github.com/tendermint/tendermint/types/time"
cdptypes "github.com/UnUniFi/chain/x/cdp/types"
)
// Parameter keys and default values
var (
KeyActive = []byte("Active")
KeyPeriods = []byte("Periods")
DefaultActive = false
DefaultPeriods = Periods{}
DefaultPreviousBlockTime = tmtime.Canonical(time.Unix(1, 0))
DefaultGovDenom = cdptypes.DefaultGovDenom
)
// NewPeriod returns a new instance of Period
func NewPeriod(start time.Time, end time.Time, inflation sdk.Dec) Period {
return Period{
Start: start,
End: end,
Inflation: inflation,
}
}
// Periods array of Period
type Periods []Period
// String implements fmt.Stringer
func (prs Periods) String() string {
out := "Periods\n"
for _, pr := range prs {
out += fmt.Sprintf("%s\n", pr)
}
return out
}
// NewParams returns a new params object
func NewParams(active bool, periods Periods) Params {
return Params{
Active: active,
Periods: periods,
}
}
// DefaultParams returns default params for ununifidist module
func DefaultParams() Params {
return NewParams(DefaultActive, DefaultPeriods)
}
// ParamKeyTable Key declaration for parameters
func ParamKeyTable() paramstype.KeyTable {
return paramstype.NewKeyTable().RegisterParamSet(&Params{})
}
// ParamSetPairs implements the ParamSet interface and returns all the key/value pairs
func (p *Params) ParamSetPairs() paramstype.ParamSetPairs {
return paramstype.ParamSetPairs{
paramstype.NewParamSetPair(KeyActive, &p.Active, validateActiveParam),
paramstype.NewParamSetPair(KeyPeriods, &p.Periods, validatePeriodsParams),
}
}
// Validate checks that the parameters have valid values.
func (p Params) Validate() error {
if err := validateActiveParam(p.Active); err != nil {
return err
}
return validatePeriodsParams(p.Periods)
}
func validateActiveParam(i interface{}) error {
_, ok := i.(bool)
if !ok {
return fmt.Errorf("invalid parameter type: %T", i)
}
return nil
}
func validatePeriodsParams(i interface{}) error {
periods, ok := i.(Periods)
if !ok {
periods, ok = i.([]Period)
if !ok {
return fmt.Errorf("invalid parameter type: %T", i)
}
}
prevEnd := tmtime.Canonical(time.Unix(0, 0))
for _, pr := range periods {
if pr.End.Before(pr.Start) {
return fmt.Errorf("end time for period is before start time: %s", pr)
}
if pr.Start.Before(prevEnd) {
return fmt.Errorf("periods must be in chronological order: %s", periods)
}
prevEnd = pr.End
if pr.Start.Unix() <= 0 || pr.End.Unix() <= 0 {
return fmt.Errorf("start or end time cannot be zero: %s", pr)
}
//TODO: validate period Inflation?
}
return nil
}