-
Notifications
You must be signed in to change notification settings - Fork 52
/
model_slo_error_timeframe.go
71 lines (60 loc) · 2.12 KB
/
model_slo_error_timeframe.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
// Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License.
// This product includes software developed at Datadog (https://www.datadoghq.com/).
// Copyright 2019-Present Datadog, Inc.
package datadogV1
import (
"fmt"
"github.com/DataDog/datadog-api-client-go/v2/api/datadog"
)
// SLOErrorTimeframe The timeframe of the threshold associated with this error
// or "all" if all thresholds are affected.
type SLOErrorTimeframe string
// List of SLOErrorTimeframe.
const (
SLOERRORTIMEFRAME_SEVEN_DAYS SLOErrorTimeframe = "7d"
SLOERRORTIMEFRAME_THIRTY_DAYS SLOErrorTimeframe = "30d"
SLOERRORTIMEFRAME_NINETY_DAYS SLOErrorTimeframe = "90d"
SLOERRORTIMEFRAME_ALL SLOErrorTimeframe = "all"
)
var allowedSLOErrorTimeframeEnumValues = []SLOErrorTimeframe{
SLOERRORTIMEFRAME_SEVEN_DAYS,
SLOERRORTIMEFRAME_THIRTY_DAYS,
SLOERRORTIMEFRAME_NINETY_DAYS,
SLOERRORTIMEFRAME_ALL,
}
// GetAllowedValues reeturns the list of possible values.
func (v *SLOErrorTimeframe) GetAllowedValues() []SLOErrorTimeframe {
return allowedSLOErrorTimeframeEnumValues
}
// UnmarshalJSON deserializes the given payload.
func (v *SLOErrorTimeframe) UnmarshalJSON(src []byte) error {
var value string
err := datadog.Unmarshal(src, &value)
if err != nil {
return err
}
*v = SLOErrorTimeframe(value)
return nil
}
// NewSLOErrorTimeframeFromValue returns a pointer to a valid SLOErrorTimeframe
// for the value passed as argument, or an error if the value passed is not allowed by the enum.
func NewSLOErrorTimeframeFromValue(v string) (*SLOErrorTimeframe, error) {
ev := SLOErrorTimeframe(v)
if ev.IsValid() {
return &ev, nil
}
return nil, fmt.Errorf("invalid value '%v' for SLOErrorTimeframe: valid values are %v", v, allowedSLOErrorTimeframeEnumValues)
}
// IsValid return true if the value is valid for the enum, false otherwise.
func (v SLOErrorTimeframe) IsValid() bool {
for _, existing := range allowedSLOErrorTimeframeEnumValues {
if existing == v {
return true
}
}
return false
}
// Ptr returns reference to SLOErrorTimeframe value.
func (v SLOErrorTimeframe) Ptr() *SLOErrorTimeframe {
return &v
}