-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmodel_integration_type.go
120 lines (98 loc) · 4.62 KB
/
model_integration_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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*
ConfigCat Public Management API
The purpose of this API is to access the ConfigCat platform programmatically. You can **Create**, **Read**, **Update** and **Delete** any entities like **Feature Flags, Configs, Environments** or **Products** within ConfigCat. **Base API URL**: https://test-api.configcat.com If you prefer the swagger documentation, you can find it here: [Swagger UI](https://test-api.configcat.com/swagger). The API is based on HTTP REST, uses resource-oriented URLs, status codes and supports JSON format. **Important:** Do not use this API for accessing and evaluating feature flag values. Use the [SDKs](https://configcat.com/docs/sdk-reference/overview) or the [ConfigCat Proxy](https://configcat.com/docs/advanced/proxy/proxy-overview/) instead. # OpenAPI Specification The complete specification is publicly available in the following formats: - [OpenAPI v3](https://test-api.configcat.com/docs/v1/swagger.json) - [Swagger v2](https://test-api.configcat.com/docs/v1/swagger.v2.json) You can use it to generate client libraries in various languages with [OpenAPI Generator](https://github.com/OpenAPITools/openapi-generator) or [Swagger Codegen](https://swagger.io/tools/swagger-codegen/) to interact with this API. # Authentication This API uses the [Basic HTTP Authentication Scheme](https://en.wikipedia.org/wiki/Basic_access_authentication). <!-- ReDoc-Inject: <security-definitions> --> # Throttling and rate limits All the rate limited API calls are returning information about the current rate limit period in the following HTTP headers: | Header | Description | | :- | :- | | X-Rate-Limit-Remaining | The maximum number of requests remaining in the current rate limit period. | | X-Rate-Limit-Reset | The time when the current rate limit period resets. | When the rate limit is exceeded by a request, the API returns with a `HTTP 429 - Too many requests` status along with a `Retry-After` HTTP header.
API version: v1
Contact: [email protected]
*/
// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
package configcatpublicapi
import (
"encoding/json"
"fmt"
)
// IntegrationType the model 'IntegrationType'
type IntegrationType string
// List of IntegrationType
const (
INTEGRATIONTYPE_DATA_DOG IntegrationType = "dataDog"
INTEGRATIONTYPE_SLACK IntegrationType = "slack"
INTEGRATIONTYPE_AMPLITUDE IntegrationType = "amplitude"
INTEGRATIONTYPE_MIX_PANEL IntegrationType = "mixPanel"
INTEGRATIONTYPE_SEGMENT IntegrationType = "segment"
INTEGRATIONTYPE_PUB_NUB IntegrationType = "pubNub"
)
// All allowed values of IntegrationType enum
var AllowedIntegrationTypeEnumValues = []IntegrationType{
"dataDog",
"slack",
"amplitude",
"mixPanel",
"segment",
"pubNub",
}
func (v *IntegrationType) UnmarshalJSON(src []byte) error {
var value string
err := json.Unmarshal(src, &value)
if err != nil {
return err
}
enumTypeValue := IntegrationType(value)
for _, existing := range AllowedIntegrationTypeEnumValues {
if existing == enumTypeValue {
*v = enumTypeValue
return nil
}
}
return fmt.Errorf("%+v is not a valid IntegrationType", value)
}
// NewIntegrationTypeFromValue returns a pointer to a valid IntegrationType
// for the value passed as argument, or an error if the value passed is not allowed by the enum
func NewIntegrationTypeFromValue(v string) (*IntegrationType, error) {
ev := IntegrationType(v)
if ev.IsValid() {
return &ev, nil
} else {
return nil, fmt.Errorf("invalid value '%v' for IntegrationType: valid values are %v", v, AllowedIntegrationTypeEnumValues)
}
}
// IsValid return true if the value is valid for the enum, false otherwise
func (v IntegrationType) IsValid() bool {
for _, existing := range AllowedIntegrationTypeEnumValues {
if existing == v {
return true
}
}
return false
}
// Ptr returns reference to IntegrationType value
func (v IntegrationType) Ptr() *IntegrationType {
return &v
}
type NullableIntegrationType struct {
value *IntegrationType
isSet bool
}
func (v NullableIntegrationType) Get() *IntegrationType {
return v.value
}
func (v *NullableIntegrationType) Set(val *IntegrationType) {
v.value = val
v.isSet = true
}
func (v NullableIntegrationType) IsSet() bool {
return v.isSet
}
func (v *NullableIntegrationType) Unset() {
v.value = nil
v.isSet = false
}
func NewNullableIntegrationType(val *IntegrationType) *NullableIntegrationType {
return &NullableIntegrationType{value: val, isSet: true}
}
func (v NullableIntegrationType) MarshalJSON() ([]byte, error) {
return json.Marshal(v.value)
}
func (v *NullableIntegrationType) UnmarshalJSON(src []byte) error {
v.isSet = true
return json.Unmarshal(src, &v.value)
}