forked from DataDog/datadog-api-client-go
/
model_logs_archive_destination_s3_type.go
105 lines (86 loc) · 2.98 KB
/
model_logs_archive_destination_s3_type.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
/*
* 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.
*/
// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
package datadog
import (
"encoding/json"
"fmt"
)
// LogsArchiveDestinationS3Type Type of the S3 archive destination.
type LogsArchiveDestinationS3Type string
// List of LogsArchiveDestinationS3Type
const (
LOGSARCHIVEDESTINATIONS3TYPE_S3 LogsArchiveDestinationS3Type = "s3"
)
var allowedLogsArchiveDestinationS3TypeEnumValues = []LogsArchiveDestinationS3Type{
"s3",
}
func (v *LogsArchiveDestinationS3Type) UnmarshalJSON(src []byte) error {
var value string
err := json.Unmarshal(src, &value)
if err != nil {
return err
}
enumTypeValue := LogsArchiveDestinationS3Type(value)
for _, existing := range allowedLogsArchiveDestinationS3TypeEnumValues {
if existing == enumTypeValue {
*v = enumTypeValue
return nil
}
}
return fmt.Errorf("%+v is not a valid LogsArchiveDestinationS3Type", value)
}
// NewLogsArchiveDestinationS3TypeFromValue returns a pointer to a valid LogsArchiveDestinationS3Type
// for the value passed as argument, or an error if the value passed is not allowed by the enum
func NewLogsArchiveDestinationS3TypeFromValue(v string) (*LogsArchiveDestinationS3Type, error) {
ev := LogsArchiveDestinationS3Type(v)
if ev.IsValid() {
return &ev, nil
} else {
return nil, fmt.Errorf("invalid value '%v' for LogsArchiveDestinationS3Type: valid values are %v", v, allowedLogsArchiveDestinationS3TypeEnumValues)
}
}
// IsValid return true if the value is valid for the enum, false otherwise
func (v LogsArchiveDestinationS3Type) IsValid() bool {
for _, existing := range allowedLogsArchiveDestinationS3TypeEnumValues {
if existing == v {
return true
}
}
return false
}
// Ptr returns reference to LogsArchiveDestinationS3Type value
func (v LogsArchiveDestinationS3Type) Ptr() *LogsArchiveDestinationS3Type {
return &v
}
type NullableLogsArchiveDestinationS3Type struct {
value *LogsArchiveDestinationS3Type
isSet bool
}
func (v NullableLogsArchiveDestinationS3Type) Get() *LogsArchiveDestinationS3Type {
return v.value
}
func (v *NullableLogsArchiveDestinationS3Type) Set(val *LogsArchiveDestinationS3Type) {
v.value = val
v.isSet = true
}
func (v NullableLogsArchiveDestinationS3Type) IsSet() bool {
return v.isSet
}
func (v *NullableLogsArchiveDestinationS3Type) Unset() {
v.value = nil
v.isSet = false
}
func NewNullableLogsArchiveDestinationS3Type(val *LogsArchiveDestinationS3Type) *NullableLogsArchiveDestinationS3Type {
return &NullableLogsArchiveDestinationS3Type{value: val, isSet: true}
}
func (v NullableLogsArchiveDestinationS3Type) MarshalJSON() ([]byte, error) {
return json.Marshal(v.value)
}
func (v *NullableLogsArchiveDestinationS3Type) UnmarshalJSON(src []byte) error {
v.isSet = true
return json.Unmarshal(src, &v.value)
}