-
Notifications
You must be signed in to change notification settings - Fork 3.3k
/
Copy pathv1alpha1_mutating_admission_policy_spec.py
286 lines (213 loc) · 14.5 KB
/
v1alpha1_mutating_admission_policy_spec.py
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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
# coding: utf-8
"""
Kubernetes
No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator) # noqa: E501
The version of the OpenAPI document: release-1.32
Generated by: https://openapi-generator.tech
"""
import pprint
import re # noqa: F401
import six
from kubernetes.client.configuration import Configuration
class V1alpha1MutatingAdmissionPolicySpec(object):
"""NOTE: This class is auto generated by OpenAPI Generator.
Ref: https://openapi-generator.tech
Do not edit the class manually.
"""
"""
Attributes:
openapi_types (dict): The key is attribute name
and the value is attribute type.
attribute_map (dict): The key is attribute name
and the value is json key in definition.
"""
openapi_types = {
'failure_policy': 'str',
'match_conditions': 'list[V1alpha1MatchCondition]',
'match_constraints': 'V1alpha1MatchResources',
'mutations': 'list[V1alpha1Mutation]',
'param_kind': 'V1alpha1ParamKind',
'reinvocation_policy': 'str',
'variables': 'list[V1alpha1Variable]'
}
attribute_map = {
'failure_policy': 'failurePolicy',
'match_conditions': 'matchConditions',
'match_constraints': 'matchConstraints',
'mutations': 'mutations',
'param_kind': 'paramKind',
'reinvocation_policy': 'reinvocationPolicy',
'variables': 'variables'
}
def __init__(self, failure_policy=None, match_conditions=None, match_constraints=None, mutations=None, param_kind=None, reinvocation_policy=None, variables=None, local_vars_configuration=None): # noqa: E501
"""V1alpha1MutatingAdmissionPolicySpec - a model defined in OpenAPI""" # noqa: E501
if local_vars_configuration is None:
local_vars_configuration = Configuration()
self.local_vars_configuration = local_vars_configuration
self._failure_policy = None
self._match_conditions = None
self._match_constraints = None
self._mutations = None
self._param_kind = None
self._reinvocation_policy = None
self._variables = None
self.discriminator = None
if failure_policy is not None:
self.failure_policy = failure_policy
if match_conditions is not None:
self.match_conditions = match_conditions
if match_constraints is not None:
self.match_constraints = match_constraints
if mutations is not None:
self.mutations = mutations
if param_kind is not None:
self.param_kind = param_kind
if reinvocation_policy is not None:
self.reinvocation_policy = reinvocation_policy
if variables is not None:
self.variables = variables
@property
def failure_policy(self):
"""Gets the failure_policy of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
failurePolicy defines how to handle failures for the admission policy. Failures can occur from CEL expression parse errors, type check errors, runtime errors and invalid or mis-configured policy definitions or bindings. A policy is invalid if paramKind refers to a non-existent Kind. A binding is invalid if paramRef.name refers to a non-existent resource. failurePolicy does not define how validations that evaluate to false are handled. Allowed values are Ignore or Fail. Defaults to Fail. # noqa: E501
:return: The failure_policy of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:rtype: str
"""
return self._failure_policy
@failure_policy.setter
def failure_policy(self, failure_policy):
"""Sets the failure_policy of this V1alpha1MutatingAdmissionPolicySpec.
failurePolicy defines how to handle failures for the admission policy. Failures can occur from CEL expression parse errors, type check errors, runtime errors and invalid or mis-configured policy definitions or bindings. A policy is invalid if paramKind refers to a non-existent Kind. A binding is invalid if paramRef.name refers to a non-existent resource. failurePolicy does not define how validations that evaluate to false are handled. Allowed values are Ignore or Fail. Defaults to Fail. # noqa: E501
:param failure_policy: The failure_policy of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:type: str
"""
self._failure_policy = failure_policy
@property
def match_conditions(self):
"""Gets the match_conditions of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
matchConditions is a list of conditions that must be met for a request to be validated. Match conditions filter requests that have already been matched by the matchConstraints. An empty list of matchConditions matches all requests. There are a maximum of 64 match conditions allowed. If a parameter object is provided, it can be accessed via the `params` handle in the same manner as validation expressions. The exact matching logic is (in order): 1. If ANY matchCondition evaluates to FALSE, the policy is skipped. 2. If ALL matchConditions evaluate to TRUE, the policy is evaluated. 3. If any matchCondition evaluates to an error (but none are FALSE): - If failurePolicy=Fail, reject the request - If failurePolicy=Ignore, the policy is skipped # noqa: E501
:return: The match_conditions of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:rtype: list[V1alpha1MatchCondition]
"""
return self._match_conditions
@match_conditions.setter
def match_conditions(self, match_conditions):
"""Sets the match_conditions of this V1alpha1MutatingAdmissionPolicySpec.
matchConditions is a list of conditions that must be met for a request to be validated. Match conditions filter requests that have already been matched by the matchConstraints. An empty list of matchConditions matches all requests. There are a maximum of 64 match conditions allowed. If a parameter object is provided, it can be accessed via the `params` handle in the same manner as validation expressions. The exact matching logic is (in order): 1. If ANY matchCondition evaluates to FALSE, the policy is skipped. 2. If ALL matchConditions evaluate to TRUE, the policy is evaluated. 3. If any matchCondition evaluates to an error (but none are FALSE): - If failurePolicy=Fail, reject the request - If failurePolicy=Ignore, the policy is skipped # noqa: E501
:param match_conditions: The match_conditions of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:type: list[V1alpha1MatchCondition]
"""
self._match_conditions = match_conditions
@property
def match_constraints(self):
"""Gets the match_constraints of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:return: The match_constraints of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:rtype: V1alpha1MatchResources
"""
return self._match_constraints
@match_constraints.setter
def match_constraints(self, match_constraints):
"""Sets the match_constraints of this V1alpha1MutatingAdmissionPolicySpec.
:param match_constraints: The match_constraints of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:type: V1alpha1MatchResources
"""
self._match_constraints = match_constraints
@property
def mutations(self):
"""Gets the mutations of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
mutations contain operations to perform on matching objects. mutations may not be empty; a minimum of one mutation is required. mutations are evaluated in order, and are reinvoked according to the reinvocationPolicy. The mutations of a policy are invoked for each binding of this policy and reinvocation of mutations occurs on a per binding basis. # noqa: E501
:return: The mutations of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:rtype: list[V1alpha1Mutation]
"""
return self._mutations
@mutations.setter
def mutations(self, mutations):
"""Sets the mutations of this V1alpha1MutatingAdmissionPolicySpec.
mutations contain operations to perform on matching objects. mutations may not be empty; a minimum of one mutation is required. mutations are evaluated in order, and are reinvoked according to the reinvocationPolicy. The mutations of a policy are invoked for each binding of this policy and reinvocation of mutations occurs on a per binding basis. # noqa: E501
:param mutations: The mutations of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:type: list[V1alpha1Mutation]
"""
self._mutations = mutations
@property
def param_kind(self):
"""Gets the param_kind of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:return: The param_kind of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:rtype: V1alpha1ParamKind
"""
return self._param_kind
@param_kind.setter
def param_kind(self, param_kind):
"""Sets the param_kind of this V1alpha1MutatingAdmissionPolicySpec.
:param param_kind: The param_kind of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:type: V1alpha1ParamKind
"""
self._param_kind = param_kind
@property
def reinvocation_policy(self):
"""Gets the reinvocation_policy of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
reinvocationPolicy indicates whether mutations may be called multiple times per MutatingAdmissionPolicyBinding as part of a single admission evaluation. Allowed values are \"Never\" and \"IfNeeded\". Never: These mutations will not be called more than once per binding in a single admission evaluation. IfNeeded: These mutations may be invoked more than once per binding for a single admission request and there is no guarantee of order with respect to other admission plugins, admission webhooks, bindings of this policy and admission policies. Mutations are only reinvoked when mutations change the object after this mutation is invoked. Required. # noqa: E501
:return: The reinvocation_policy of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:rtype: str
"""
return self._reinvocation_policy
@reinvocation_policy.setter
def reinvocation_policy(self, reinvocation_policy):
"""Sets the reinvocation_policy of this V1alpha1MutatingAdmissionPolicySpec.
reinvocationPolicy indicates whether mutations may be called multiple times per MutatingAdmissionPolicyBinding as part of a single admission evaluation. Allowed values are \"Never\" and \"IfNeeded\". Never: These mutations will not be called more than once per binding in a single admission evaluation. IfNeeded: These mutations may be invoked more than once per binding for a single admission request and there is no guarantee of order with respect to other admission plugins, admission webhooks, bindings of this policy and admission policies. Mutations are only reinvoked when mutations change the object after this mutation is invoked. Required. # noqa: E501
:param reinvocation_policy: The reinvocation_policy of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:type: str
"""
self._reinvocation_policy = reinvocation_policy
@property
def variables(self):
"""Gets the variables of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
variables contain definitions of variables that can be used in composition of other expressions. Each variable is defined as a named CEL expression. The variables defined here will be available under `variables` in other expressions of the policy except matchConditions because matchConditions are evaluated before the rest of the policy. The expression of a variable can refer to other variables defined earlier in the list but not those after. Thus, variables must be sorted by the order of first appearance and acyclic. # noqa: E501
:return: The variables of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:rtype: list[V1alpha1Variable]
"""
return self._variables
@variables.setter
def variables(self, variables):
"""Sets the variables of this V1alpha1MutatingAdmissionPolicySpec.
variables contain definitions of variables that can be used in composition of other expressions. Each variable is defined as a named CEL expression. The variables defined here will be available under `variables` in other expressions of the policy except matchConditions because matchConditions are evaluated before the rest of the policy. The expression of a variable can refer to other variables defined earlier in the list but not those after. Thus, variables must be sorted by the order of first appearance and acyclic. # noqa: E501
:param variables: The variables of this V1alpha1MutatingAdmissionPolicySpec. # noqa: E501
:type: list[V1alpha1Variable]
"""
self._variables = variables
def to_dict(self):
"""Returns the model properties as a dict"""
result = {}
for attr, _ in six.iteritems(self.openapi_types):
value = getattr(self, attr)
if isinstance(value, list):
result[attr] = list(map(
lambda x: x.to_dict() if hasattr(x, "to_dict") else x,
value
))
elif hasattr(value, "to_dict"):
result[attr] = value.to_dict()
elif isinstance(value, dict):
result[attr] = dict(map(
lambda item: (item[0], item[1].to_dict())
if hasattr(item[1], "to_dict") else item,
value.items()
))
else:
result[attr] = value
return result
def to_str(self):
"""Returns the string representation of the model"""
return pprint.pformat(self.to_dict())
def __repr__(self):
"""For `print` and `pprint`"""
return self.to_str()
def __eq__(self, other):
"""Returns true if both objects are equal"""
if not isinstance(other, V1alpha1MutatingAdmissionPolicySpec):
return False
return self.to_dict() == other.to_dict()
def __ne__(self, other):
"""Returns true if both objects are not equal"""
if not isinstance(other, V1alpha1MutatingAdmissionPolicySpec):
return True
return self.to_dict() != other.to_dict()