-
Notifications
You must be signed in to change notification settings - Fork 3.3k
/
Copy pathv1_validating_admission_policy_spec.py
286 lines (213 loc) · 13.6 KB
/
v1_validating_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 V1ValidatingAdmissionPolicySpec(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 = {
'audit_annotations': 'list[V1AuditAnnotation]',
'failure_policy': 'str',
'match_conditions': 'list[V1MatchCondition]',
'match_constraints': 'V1MatchResources',
'param_kind': 'V1ParamKind',
'validations': 'list[V1Validation]',
'variables': 'list[V1Variable]'
}
attribute_map = {
'audit_annotations': 'auditAnnotations',
'failure_policy': 'failurePolicy',
'match_conditions': 'matchConditions',
'match_constraints': 'matchConstraints',
'param_kind': 'paramKind',
'validations': 'validations',
'variables': 'variables'
}
def __init__(self, audit_annotations=None, failure_policy=None, match_conditions=None, match_constraints=None, param_kind=None, validations=None, variables=None, local_vars_configuration=None): # noqa: E501
"""V1ValidatingAdmissionPolicySpec - 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._audit_annotations = None
self._failure_policy = None
self._match_conditions = None
self._match_constraints = None
self._param_kind = None
self._validations = None
self._variables = None
self.discriminator = None
if audit_annotations is not None:
self.audit_annotations = audit_annotations
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 param_kind is not None:
self.param_kind = param_kind
if validations is not None:
self.validations = validations
if variables is not None:
self.variables = variables
@property
def audit_annotations(self):
"""Gets the audit_annotations of this V1ValidatingAdmissionPolicySpec. # noqa: E501
auditAnnotations contains CEL expressions which are used to produce audit annotations for the audit event of the API request. validations and auditAnnotations may not both be empty; a least one of validations or auditAnnotations is required. # noqa: E501
:return: The audit_annotations of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:rtype: list[V1AuditAnnotation]
"""
return self._audit_annotations
@audit_annotations.setter
def audit_annotations(self, audit_annotations):
"""Sets the audit_annotations of this V1ValidatingAdmissionPolicySpec.
auditAnnotations contains CEL expressions which are used to produce audit annotations for the audit event of the API request. validations and auditAnnotations may not both be empty; a least one of validations or auditAnnotations is required. # noqa: E501
:param audit_annotations: The audit_annotations of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:type: list[V1AuditAnnotation]
"""
self._audit_annotations = audit_annotations
@property
def failure_policy(self):
"""Gets the failure_policy of this V1ValidatingAdmissionPolicySpec. # 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 spec.paramKind refers to a non-existent Kind. A binding is invalid if spec.paramRef.name refers to a non-existent resource. failurePolicy does not define how validations that evaluate to false are handled. When failurePolicy is set to Fail, ValidatingAdmissionPolicyBinding validationActions define how failures are enforced. Allowed values are Ignore or Fail. Defaults to Fail. # noqa: E501
:return: The failure_policy of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:rtype: str
"""
return self._failure_policy
@failure_policy.setter
def failure_policy(self, failure_policy):
"""Sets the failure_policy of this V1ValidatingAdmissionPolicySpec.
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 spec.paramKind refers to a non-existent Kind. A binding is invalid if spec.paramRef.name refers to a non-existent resource. failurePolicy does not define how validations that evaluate to false are handled. When failurePolicy is set to Fail, ValidatingAdmissionPolicyBinding validationActions define how failures are enforced. Allowed values are Ignore or Fail. Defaults to Fail. # noqa: E501
:param failure_policy: The failure_policy of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:type: str
"""
self._failure_policy = failure_policy
@property
def match_conditions(self):
"""Gets the match_conditions of this V1ValidatingAdmissionPolicySpec. # 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 rules, namespaceSelector, and objectSelector. 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 V1ValidatingAdmissionPolicySpec. # noqa: E501
:rtype: list[V1MatchCondition]
"""
return self._match_conditions
@match_conditions.setter
def match_conditions(self, match_conditions):
"""Sets the match_conditions of this V1ValidatingAdmissionPolicySpec.
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 rules, namespaceSelector, and objectSelector. 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 V1ValidatingAdmissionPolicySpec. # noqa: E501
:type: list[V1MatchCondition]
"""
self._match_conditions = match_conditions
@property
def match_constraints(self):
"""Gets the match_constraints of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:return: The match_constraints of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:rtype: V1MatchResources
"""
return self._match_constraints
@match_constraints.setter
def match_constraints(self, match_constraints):
"""Sets the match_constraints of this V1ValidatingAdmissionPolicySpec.
:param match_constraints: The match_constraints of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:type: V1MatchResources
"""
self._match_constraints = match_constraints
@property
def param_kind(self):
"""Gets the param_kind of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:return: The param_kind of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:rtype: V1ParamKind
"""
return self._param_kind
@param_kind.setter
def param_kind(self, param_kind):
"""Sets the param_kind of this V1ValidatingAdmissionPolicySpec.
:param param_kind: The param_kind of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:type: V1ParamKind
"""
self._param_kind = param_kind
@property
def validations(self):
"""Gets the validations of this V1ValidatingAdmissionPolicySpec. # noqa: E501
Validations contain CEL expressions which is used to apply the validation. Validations and AuditAnnotations may not both be empty; a minimum of one Validations or AuditAnnotations is required. # noqa: E501
:return: The validations of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:rtype: list[V1Validation]
"""
return self._validations
@validations.setter
def validations(self, validations):
"""Sets the validations of this V1ValidatingAdmissionPolicySpec.
Validations contain CEL expressions which is used to apply the validation. Validations and AuditAnnotations may not both be empty; a minimum of one Validations or AuditAnnotations is required. # noqa: E501
:param validations: The validations of this V1ValidatingAdmissionPolicySpec. # noqa: E501
:type: list[V1Validation]
"""
self._validations = validations
@property
def variables(self):
"""Gets the variables of this V1ValidatingAdmissionPolicySpec. # 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 V1ValidatingAdmissionPolicySpec. # noqa: E501
:rtype: list[V1Variable]
"""
return self._variables
@variables.setter
def variables(self, variables):
"""Sets the variables of this V1ValidatingAdmissionPolicySpec.
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 V1ValidatingAdmissionPolicySpec. # noqa: E501
:type: list[V1Variable]
"""
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, V1ValidatingAdmissionPolicySpec):
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, V1ValidatingAdmissionPolicySpec):
return True
return self.to_dict() != other.to_dict()