blob: 02b1d3dc754db841dd644b3642425c4afc591db3 [file] [log] [blame]
Kent Hagerman1e9061e2019-05-21 16:01:21 -04001/*
2 * Copyright 2019-present Open Networking Foundation
3
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7
8 * http://www.apache.org/licenses/LICENSE-2.0
9
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package afrouter
18
19import (
20 "encoding/json"
21 "fmt"
22)
23
24type backendType int
25
26const (
27 BackendUndefined backendType = iota
28 BackendActiveActive
29 BackendSingleServer
30)
31
32var stringToBeType = map[string]backendType{"active_active": BackendActiveActive, "server": BackendSingleServer}
33var beTypeToString = map[backendType]string{BackendActiveActive: "active_active", BackendSingleServer: "server"}
34
35func (t backendType) MarshalJSON() ([]byte, error) {
36 if t == BackendUndefined {
37 return json.Marshal(nil)
38 }
39 if str, have := beTypeToString[t]; have {
40 return json.Marshal(str)
41 }
42 return nil, fmt.Errorf("unknown %T '%d'", t, t)
43}
44
45func (t *backendType) UnmarshalJSON(b []byte) error {
46 var str string
47 if err := json.Unmarshal(b, &str); err != nil {
48 return err
49 }
50 var have bool
51 if *t, have = stringToBeType[str]; !have {
52 return fmt.Errorf("invalid %T %s", *t, str)
53 }
54 return nil
55}
56
57type associationLocation int
58
59const (
60 AssociationLocationUndefined associationLocation = iota
61 AssociationLocationHeader
62 AssociationLocationProtobuf
63)
64
65var stringToAlType = map[string]associationLocation{"header": AssociationLocationHeader, "protobuf": AssociationLocationProtobuf}
66var alTypeToString = map[associationLocation]string{AssociationLocationHeader: "header", AssociationLocationProtobuf: "protobuf"}
67
68func (t associationLocation) MarshalJSON() ([]byte, error) {
69 if t == AssociationLocationUndefined {
70 return json.Marshal(nil)
71 }
72 if str, have := alTypeToString[t]; have {
73 return json.Marshal(str)
74 }
75 return nil, fmt.Errorf("unknown %T '%d'", t, t)
76}
77
78func (t *associationLocation) UnmarshalJSON(b []byte) error {
79 var str string
80 if err := json.Unmarshal(b, &str); err != nil {
81 return err
82 }
83 var have bool
84 if *t, have = stringToAlType[str]; !have {
85 return fmt.Errorf("invalid %T %s", *t, str)
86 }
87 return nil
88}
89
90type associationStrategy int
91
92const (
93 AssociationStrategyUndefined associationStrategy = iota
94 AssociationStrategySerialNo
95)
96
97var stringToAsType = map[string]associationStrategy{"serial_number": AssociationStrategySerialNo}
98var asTypeToString = map[associationStrategy]string{AssociationStrategySerialNo: "serial_number"}
99
100func (t associationStrategy) MarshalJSON() ([]byte, error) {
101 if t == AssociationStrategyUndefined {
102 return json.Marshal(nil)
103 }
104 if str, have := asTypeToString[t]; have {
105 return json.Marshal(str)
106 }
107 return nil, fmt.Errorf("unknown %T '%d'", t, t)
108}
109
110func (t *associationStrategy) UnmarshalJSON(b []byte) error {
111 var str string
112 if err := json.Unmarshal(b, &str); err != nil {
113 return err
114 }
115 var have bool
116 if *t, have = stringToAsType[str]; !have {
117 return fmt.Errorf("invalid %T %s", *t, str)
118 }
119 return nil
120}
121
122type backendSequence int
123
124const (
125 BackendSequenceRoundRobin backendSequence = iota
126)
127
128type routeType int
129
130const (
131 RouteTypeUndefined routeType = iota
132 RouteTypeRpcAffinityMessage
133 RouteTypeRpcAffinityHeader
134 RouteTypeBinding
135 RouteTypeRoundRobin
136)
137
138// String names for display in error messages.
139var stringToRouteType = map[string]routeType{"rpc_affinity_message": RouteTypeRpcAffinityMessage, "rpc_affinity_header": RouteTypeRpcAffinityHeader, "binding": RouteTypeBinding, "round_robin": RouteTypeRoundRobin}
140var routeTypeToString = map[routeType]string{RouteTypeRpcAffinityMessage: "rpc_affinity_message", RouteTypeRpcAffinityHeader: "rpc_affinity_header", RouteTypeBinding: "binding", RouteTypeRoundRobin: "round_robin"}
141
142func (t routeType) String() string {
143 if str, have := routeTypeToString[t]; have {
144 return str
145 }
146 return fmt.Sprintf("%T(%d)", t, t)
147}
148
149func (t routeType) MarshalJSON() ([]byte, error) {
150 if t == RouteTypeUndefined {
151 return json.Marshal(nil)
152 }
153 if str, have := routeTypeToString[t]; have {
154 return json.Marshal(str)
155 }
156 return nil, fmt.Errorf("unknown %T '%d'", t, t)
157}
158
159func (t *routeType) UnmarshalJSON(b []byte) error {
160 var str string
161 if err := json.Unmarshal(b, &str); err != nil {
162 return err
163 }
164 var have bool
165 if *t, have = stringToRouteType[str]; !have {
166 return fmt.Errorf("invalid %T %s", *t, str)
167 }
168 return nil
169}
170
171type associationType int
172
173const (
174 AssociationUndefined associationType = iota
175 AssociationRoundRobin
176)
177
178var stringToAssociationType = map[string]associationType{"round_robin": AssociationRoundRobin}
179var associationTypeToString = map[associationType]string{AssociationRoundRobin: "round_robin"}
180
181func (t associationType) MarshalJSON() ([]byte, error) {
182 if t == AssociationUndefined {
183 return json.Marshal(nil)
184 }
185 if str, have := associationTypeToString[t]; have {
186 return json.Marshal(str)
187 }
188 return nil, fmt.Errorf("unknown %T '%d'", t, t)
189}
190
191func (t *associationType) UnmarshalJSON(b []byte) error {
192 var str string
193 if err := json.Unmarshal(b, &str); err != nil {
194 return err
195 }
196 var have bool
197 if *t, have = stringToAssociationType[str]; !have {
198 return fmt.Errorf("invalid %T %s", *t, str)
199 }
200 return nil
201}