-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathmultirange.go
142 lines (129 loc) · 4.54 KB
/
multirange.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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
package redis_timeseries_go
import (
"fmt"
"strconv"
)
// MultiRangeOptions represent the options for querying across multiple time-series
type MultiRangeOptions struct {
AggType AggregationType
TimeBucket int
Count int64
WithLabels bool
SelectedLabels []string
Align int64
FilterByTs []int64
FilterByValueMin *float64
FilterByValueMax *float64
GroupBy string
Reduce ReducerType
}
// MultiRangeOptions are the default options for querying across multiple time-series
var DefaultMultiRangeOptions = MultiRangeOptions{
AggType: "",
TimeBucket: -1,
Count: -1,
WithLabels: false,
SelectedLabels: []string{},
Align: -1,
FilterByTs: []int64{},
FilterByValueMin: nil,
FilterByValueMax: nil,
GroupBy: "",
Reduce: "",
}
func NewMultiRangeOptions() *MultiRangeOptions {
return &MultiRangeOptions{
AggType: "",
TimeBucket: -1,
Count: -1,
WithLabels: false,
SelectedLabels: []string{},
Align: -1,
FilterByTs: []int64{},
FilterByValueMin: nil,
FilterByValueMax: nil,
GroupBy: "",
Reduce: "",
}
}
// SetGroupByReduce Aggregates results across different time series, grouped by the provided label name.
// When combined with AGGREGATION the groupby/reduce is applied post aggregation stage.
func (mrangeopts *MultiRangeOptions) SetGroupByReduce(byLabel string, reducer ReducerType) *MultiRangeOptions {
mrangeopts.GroupBy = byLabel
mrangeopts.Reduce = reducer
return mrangeopts
}
// SetAlign sets the time bucket alignment control for AGGREGATION.
// This will control the time bucket timestamps by changing the reference timestamp on which a bucket is defined.
func (mrangeopts *MultiRangeOptions) SetAlign(byTimeStamp int64) *MultiRangeOptions {
mrangeopts.Align = byTimeStamp
return mrangeopts
}
// SetFilterByTs sets the list of timestamps to filter the result by specific timestamps
func (mrangeopts *MultiRangeOptions) SetFilterByTs(filterByTS []int64) *MultiRangeOptions {
mrangeopts.FilterByTs = filterByTS
return mrangeopts
}
// SetFilterByValue filters the result by value using minimum and maximum ( inclusive )
func (mrangeopts *MultiRangeOptions) SetFilterByValue(min, max float64) *MultiRangeOptions {
mrangeopts.FilterByValueMin = &min
mrangeopts.FilterByValueMax = &max
return mrangeopts
}
func (mrangeopts *MultiRangeOptions) SetCount(count int64) *MultiRangeOptions {
mrangeopts.Count = count
return mrangeopts
}
func (mrangeopts *MultiRangeOptions) SetAggregation(aggType AggregationType, timeBucket int) *MultiRangeOptions {
mrangeopts.AggType = aggType
mrangeopts.TimeBucket = timeBucket
return mrangeopts
}
func (mrangeopts *MultiRangeOptions) SetWithLabels(value bool) *MultiRangeOptions {
mrangeopts.WithLabels = value
return mrangeopts
}
// SetSelectedLabels limits the series reply labels to provided label names
func (mrangeopts *MultiRangeOptions) SetSelectedLabels(labels []string) *MultiRangeOptions {
mrangeopts.SelectedLabels = labels
return mrangeopts
}
func createMultiRangeCmdArguments(fromTimestamp int64, toTimestamp int64, mrangeOptions MultiRangeOptions, filters []string) []interface{} {
args := []interface{}{strconv.FormatInt(fromTimestamp, 10), strconv.FormatInt(toTimestamp, 10)}
if mrangeOptions.FilterByValueMin != nil {
args = append(args, "FILTER_BY_VALUE",
fmt.Sprintf("%f", *mrangeOptions.FilterByValueMin),
fmt.Sprintf("%f", *mrangeOptions.FilterByValueMax))
}
if len(mrangeOptions.FilterByTs) > 0 {
args = append(args, "FILTER_BY_TS")
for _, timestamp := range mrangeOptions.FilterByTs {
args = append(args, strconv.FormatInt(timestamp, 10))
}
}
if mrangeOptions.AggType != "" {
args = append(args, "AGGREGATION", mrangeOptions.AggType, strconv.Itoa(mrangeOptions.TimeBucket))
}
if mrangeOptions.Count != -1 {
args = append(args, "COUNT", strconv.FormatInt(mrangeOptions.Count, 10))
}
if mrangeOptions.WithLabels {
args = append(args, "WITHLABELS")
} else if len(mrangeOptions.SelectedLabels) > 0 {
args = append(args, "SELECTED_LABELS")
for _, label := range mrangeOptions.SelectedLabels {
args = append(args, label)
}
}
if mrangeOptions.Align != -1 {
args = append(args, "ALIGN", strconv.FormatInt(mrangeOptions.Align, 10))
}
args = append(args, "FILTER")
for _, filter := range filters {
args = append(args, filter)
}
if mrangeOptions.GroupBy != "" {
args = append(args, "GROUPBY", mrangeOptions.GroupBy, "REDUCE", string(mrangeOptions.Reduce))
}
return args
}