forked from MyPureCloud/platform-client-sdk-go
/
developmentactivityaggregateparam.go
104 lines (71 loc) · 3.23 KB
/
developmentactivityaggregateparam.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
package platformclientv2
import (
"github.com/leekchan/timeutil"
"encoding/json"
"fmt"
"strconv"
"strings"
)
// Developmentactivityaggregateparam
type Developmentactivityaggregateparam struct {
// Interval - Specifies the range of due dates to be used for filtering. Milliseconds will be truncated. A maximum of 1 year can be specified in the range. End date is not inclusive. 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"`
// Metrics - The list of metrics to be returned. If omitted, all metrics are returned.
Metrics *[]string `json:"metrics,omitempty"`
// GroupBy - Specifies if the aggregated data is combined into a single set of metrics (groupBy is empty or not specified), or contains an element per attendeeId (groupBy is \"attendeeId\")
GroupBy *[]string `json:"groupBy,omitempty"`
// Filter - The filter applied to the data. This is ANDed with the interval parameter.
Filter *Developmentactivityaggregatequeryrequestfilter `json:"filter"`
}
func (o *Developmentactivityaggregateparam) MarshalJSON() ([]byte, error) {
// Redundant initialization to avoid unused import errors for models with no Time values
_ = timeutil.Timedelta{}
type Alias Developmentactivityaggregateparam
return json.Marshal(&struct {
Interval *string `json:"interval,omitempty"`
Metrics *[]string `json:"metrics,omitempty"`
GroupBy *[]string `json:"groupBy,omitempty"`
Filter *Developmentactivityaggregatequeryrequestfilter `json:"filter"`
*Alias
}{
Interval: o.Interval,
Metrics: o.Metrics,
GroupBy: o.GroupBy,
Filter: o.Filter,
Alias: (*Alias)(o),
})
}
func (o *Developmentactivityaggregateparam) UnmarshalJSON(b []byte) error {
var DevelopmentactivityaggregateparamMap map[string]interface{}
err := json.Unmarshal(b, &DevelopmentactivityaggregateparamMap)
if err != nil {
return err
}
if Interval, ok := DevelopmentactivityaggregateparamMap["interval"].(string); ok {
o.Interval = &Interval
}
if Metrics, ok := DevelopmentactivityaggregateparamMap["metrics"].([]interface{}); ok {
MetricsString, _ := json.Marshal(Metrics)
json.Unmarshal(MetricsString, &o.Metrics)
}
if GroupBy, ok := DevelopmentactivityaggregateparamMap["groupBy"].([]interface{}); ok {
GroupByString, _ := json.Marshal(GroupBy)
json.Unmarshal(GroupByString, &o.GroupBy)
}
if Filter, ok := DevelopmentactivityaggregateparamMap["filter"].(map[string]interface{}); ok {
FilterString, _ := json.Marshal(Filter)
json.Unmarshal(FilterString, &o.Filter)
}
return nil
}
// String returns a JSON representation of the model
func (o *Developmentactivityaggregateparam) String() string {
j, _ := json.Marshal(o)
str, _ := strconv.Unquote(strings.Replace(strconv.Quote(string(j)), `\\u`, `\u`, -1))
str = strings.Replace(str, strconv.Quote(*NullString()), "null", -1)
str = strings.Replace(str, fmt.Sprintf("%v", *NullInt()), "null", -1)
str = strings.Replace(str, fmt.Sprintf("%v", *NullFloat32()), "null", -1)
str = strings.Replace(str, fmt.Sprintf("%v", *NullFloat64()), "null", -1)
str = strings.Replace(str, fmt.Sprintf("%v", NullTime().Format("2006-01-02T15:04:05Z07:00")), "null", -1)
return str
}