-
Notifications
You must be signed in to change notification settings - Fork 82
/
resolver_rule.go
138 lines (114 loc) · 4.45 KB
/
resolver_rule.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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
// Copyright (c) 2016, 2018, 2024, Oracle and/or its affiliates. All rights reserved.
// This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
// Code generated. DO NOT EDIT.
// DNS API
//
// API for the DNS service. Use this API to manage DNS zones, records, and other DNS resources.
// For more information, see Overview of the DNS Service (https://docs.cloud.oracle.com/iaas/Content/DNS/Concepts/dnszonemanagement.htm).
//
package dns
import (
"encoding/json"
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// ResolverRule A rule for a resolver. Specifying both qnameCoverConditions and clientAddressConditions is not allowed.
// **Warning:** Oracle recommends that you avoid using any confidential information when you supply string values using the API.
type ResolverRule interface {
// A list of CIDR blocks. The query must come from a client within one of the blocks in order for the rule action
// to apply.
GetClientAddressConditions() []string
// A list of domain names. The query must be covered by one of the domains in order for the rule action to apply.
GetQnameCoverConditions() []string
}
type resolverrule struct {
JsonData []byte
ClientAddressConditions []string `mandatory:"true" json:"clientAddressConditions"`
QnameCoverConditions []string `mandatory:"true" json:"qnameCoverConditions"`
Action string `json:"action"`
}
// UnmarshalJSON unmarshals json
func (m *resolverrule) UnmarshalJSON(data []byte) error {
m.JsonData = data
type Unmarshalerresolverrule resolverrule
s := struct {
Model Unmarshalerresolverrule
}{}
err := json.Unmarshal(data, &s.Model)
if err != nil {
return err
}
m.ClientAddressConditions = s.Model.ClientAddressConditions
m.QnameCoverConditions = s.Model.QnameCoverConditions
m.Action = s.Model.Action
return err
}
// UnmarshalPolymorphicJSON unmarshals polymorphic json
func (m *resolverrule) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) {
if data == nil || string(data) == "null" {
return nil, nil
}
var err error
switch m.Action {
case "FORWARD":
mm := ResolverForwardRule{}
err = json.Unmarshal(data, &mm)
return mm, err
default:
common.Logf("Recieved unsupported enum value for ResolverRule: %s.", m.Action)
return *m, nil
}
}
// GetClientAddressConditions returns ClientAddressConditions
func (m resolverrule) GetClientAddressConditions() []string {
return m.ClientAddressConditions
}
// GetQnameCoverConditions returns QnameCoverConditions
func (m resolverrule) GetQnameCoverConditions() []string {
return m.QnameCoverConditions
}
func (m resolverrule) String() string {
return common.PointerString(m)
}
// ValidateEnumValue returns an error when providing an unsupported enum value
// This function is being called during constructing API request process
// Not recommended for calling this function directly
func (m resolverrule) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// ResolverRuleActionEnum Enum with underlying type: string
type ResolverRuleActionEnum string
// Set of constants representing the allowable values for ResolverRuleActionEnum
const (
ResolverRuleActionForward ResolverRuleActionEnum = "FORWARD"
)
var mappingResolverRuleActionEnum = map[string]ResolverRuleActionEnum{
"FORWARD": ResolverRuleActionForward,
}
var mappingResolverRuleActionEnumLowerCase = map[string]ResolverRuleActionEnum{
"forward": ResolverRuleActionForward,
}
// GetResolverRuleActionEnumValues Enumerates the set of values for ResolverRuleActionEnum
func GetResolverRuleActionEnumValues() []ResolverRuleActionEnum {
values := make([]ResolverRuleActionEnum, 0)
for _, v := range mappingResolverRuleActionEnum {
values = append(values, v)
}
return values
}
// GetResolverRuleActionEnumStringValues Enumerates the set of values in String for ResolverRuleActionEnum
func GetResolverRuleActionEnumStringValues() []string {
return []string{
"FORWARD",
}
}
// GetMappingResolverRuleActionEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingResolverRuleActionEnum(val string) (ResolverRuleActionEnum, bool) {
enum, ok := mappingResolverRuleActionEnumLowerCase[strings.ToLower(val)]
return enum, ok
}