-
Notifications
You must be signed in to change notification settings - Fork 12
/
evaluationaggregationqueryme.go
113 lines (78 loc) · 3.65 KB
/
evaluationaggregationqueryme.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 platformclientv2
import (
"github.com/leekchan/timeutil"
"encoding/json"
"strconv"
"strings"
)
// Evaluationaggregationqueryme
type Evaluationaggregationqueryme struct {
// Interval - Behaves like one clause in a SQL WHERE. Specifies the date and time range of data being queried. Intervals are represented as an ISO-8601 string. For example: YYYY-MM-DDThh:mm:ss/YYYY-MM-DDThh:mm:ss
Interval *string `json:"interval,omitempty"`
// TimeZone - Time zone context used to calculate response intervals (this allows resolving DST changes). The interval offset is used even when timeZone is specified. Default is UTC. Time zones are represented as a string of the zone name as found in the IANA time zone database. For example: UTC, Etc/UTC, or Europe/London
TimeZone *string `json:"timeZone,omitempty"`
// GroupBy - Behaves like a SQL GROUPBY. Allows for multiple levels of grouping as a list of dimensions. Partitions resulting aggregate computations into distinct named subgroups rather than across the entire result set as if it were one group.
GroupBy *[]string `json:"groupBy,omitempty"`
// Metrics - Behaves like a SQL SELECT clause. Only named metrics will be retrieved.
Metrics *[]string `json:"metrics,omitempty"`
// AlternateTimeDimension - Dimension to use as the alternative timestamp for data in the aggregate. Choosing \"eventTime\" uses the actual time of the data event.
AlternateTimeDimension *string `json:"alternateTimeDimension,omitempty"`
// ContextId - Evaluation context Id
ContextId *string `json:"contextId,omitempty"`
}
func (o *Evaluationaggregationqueryme) MarshalJSON() ([]byte, error) {
// Redundant initialization to avoid unused import errors for models with no Time values
_ = timeutil.Timedelta{}
type Alias Evaluationaggregationqueryme
return json.Marshal(&struct {
Interval *string `json:"interval,omitempty"`
TimeZone *string `json:"timeZone,omitempty"`
GroupBy *[]string `json:"groupBy,omitempty"`
Metrics *[]string `json:"metrics,omitempty"`
AlternateTimeDimension *string `json:"alternateTimeDimension,omitempty"`
ContextId *string `json:"contextId,omitempty"`
*Alias
}{
Interval: o.Interval,
TimeZone: o.TimeZone,
GroupBy: o.GroupBy,
Metrics: o.Metrics,
AlternateTimeDimension: o.AlternateTimeDimension,
ContextId: o.ContextId,
Alias: (*Alias)(o),
})
}
func (o *Evaluationaggregationqueryme) UnmarshalJSON(b []byte) error {
var EvaluationaggregationquerymeMap map[string]interface{}
err := json.Unmarshal(b, &EvaluationaggregationquerymeMap)
if err != nil {
return err
}
if Interval, ok := EvaluationaggregationquerymeMap["interval"].(string); ok {
o.Interval = &Interval
}
if TimeZone, ok := EvaluationaggregationquerymeMap["timeZone"].(string); ok {
o.TimeZone = &TimeZone
}
if GroupBy, ok := EvaluationaggregationquerymeMap["groupBy"].([]interface{}); ok {
GroupByString, _ := json.Marshal(GroupBy)
json.Unmarshal(GroupByString, &o.GroupBy)
}
if Metrics, ok := EvaluationaggregationquerymeMap["metrics"].([]interface{}); ok {
MetricsString, _ := json.Marshal(Metrics)
json.Unmarshal(MetricsString, &o.Metrics)
}
if AlternateTimeDimension, ok := EvaluationaggregationquerymeMap["alternateTimeDimension"].(string); ok {
o.AlternateTimeDimension = &AlternateTimeDimension
}
if ContextId, ok := EvaluationaggregationquerymeMap["contextId"].(string); ok {
o.ContextId = &ContextId
}
return nil
}
// String returns a JSON representation of the model
func (o *Evaluationaggregationqueryme) String() string {
j, _ := json.Marshal(o)
str, _ := strconv.Unquote(strings.Replace(strconv.Quote(string(j)), `\\u`, `\u`, -1))
return str
}