205 lines
9.5 KiB
Python
205 lines
9.5 KiB
Python
# 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 V1NetworkPolicySpec(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 = {
|
|
'egress': 'list[V1NetworkPolicyEgressRule]',
|
|
'ingress': 'list[V1NetworkPolicyIngressRule]',
|
|
'pod_selector': 'V1LabelSelector',
|
|
'policy_types': 'list[str]'
|
|
}
|
|
|
|
attribute_map = {
|
|
'egress': 'egress',
|
|
'ingress': 'ingress',
|
|
'pod_selector': 'podSelector',
|
|
'policy_types': 'policyTypes'
|
|
}
|
|
|
|
def __init__(self, egress=None, ingress=None, pod_selector=None, policy_types=None, local_vars_configuration=None): # noqa: E501
|
|
"""V1NetworkPolicySpec - 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._egress = None
|
|
self._ingress = None
|
|
self._pod_selector = None
|
|
self._policy_types = None
|
|
self.discriminator = None
|
|
|
|
if egress is not None:
|
|
self.egress = egress
|
|
if ingress is not None:
|
|
self.ingress = ingress
|
|
self.pod_selector = pod_selector
|
|
if policy_types is not None:
|
|
self.policy_types = policy_types
|
|
|
|
@property
|
|
def egress(self):
|
|
"""Gets the egress of this V1NetworkPolicySpec. # noqa: E501
|
|
|
|
egress is a list of egress rules to be applied to the selected pods. Outgoing traffic is allowed if there are no NetworkPolicies selecting the pod (and cluster policy otherwise allows the traffic), OR if the traffic matches at least one egress rule across all of the NetworkPolicy objects whose podSelector matches the pod. If this field is empty then this NetworkPolicy limits all outgoing traffic (and serves solely to ensure that the pods it selects are isolated by default). This field is beta-level in 1.8 # noqa: E501
|
|
|
|
:return: The egress of this V1NetworkPolicySpec. # noqa: E501
|
|
:rtype: list[V1NetworkPolicyEgressRule]
|
|
"""
|
|
return self._egress
|
|
|
|
@egress.setter
|
|
def egress(self, egress):
|
|
"""Sets the egress of this V1NetworkPolicySpec.
|
|
|
|
egress is a list of egress rules to be applied to the selected pods. Outgoing traffic is allowed if there are no NetworkPolicies selecting the pod (and cluster policy otherwise allows the traffic), OR if the traffic matches at least one egress rule across all of the NetworkPolicy objects whose podSelector matches the pod. If this field is empty then this NetworkPolicy limits all outgoing traffic (and serves solely to ensure that the pods it selects are isolated by default). This field is beta-level in 1.8 # noqa: E501
|
|
|
|
:param egress: The egress of this V1NetworkPolicySpec. # noqa: E501
|
|
:type: list[V1NetworkPolicyEgressRule]
|
|
"""
|
|
|
|
self._egress = egress
|
|
|
|
@property
|
|
def ingress(self):
|
|
"""Gets the ingress of this V1NetworkPolicySpec. # noqa: E501
|
|
|
|
ingress is a list of ingress rules to be applied to the selected pods. Traffic is allowed to a pod if there are no NetworkPolicies selecting the pod (and cluster policy otherwise allows the traffic), OR if the traffic source is the pod's local node, OR if the traffic matches at least one ingress rule across all of the NetworkPolicy objects whose podSelector matches the pod. If this field is empty then this NetworkPolicy does not allow any traffic (and serves solely to ensure that the pods it selects are isolated by default) # noqa: E501
|
|
|
|
:return: The ingress of this V1NetworkPolicySpec. # noqa: E501
|
|
:rtype: list[V1NetworkPolicyIngressRule]
|
|
"""
|
|
return self._ingress
|
|
|
|
@ingress.setter
|
|
def ingress(self, ingress):
|
|
"""Sets the ingress of this V1NetworkPolicySpec.
|
|
|
|
ingress is a list of ingress rules to be applied to the selected pods. Traffic is allowed to a pod if there are no NetworkPolicies selecting the pod (and cluster policy otherwise allows the traffic), OR if the traffic source is the pod's local node, OR if the traffic matches at least one ingress rule across all of the NetworkPolicy objects whose podSelector matches the pod. If this field is empty then this NetworkPolicy does not allow any traffic (and serves solely to ensure that the pods it selects are isolated by default) # noqa: E501
|
|
|
|
:param ingress: The ingress of this V1NetworkPolicySpec. # noqa: E501
|
|
:type: list[V1NetworkPolicyIngressRule]
|
|
"""
|
|
|
|
self._ingress = ingress
|
|
|
|
@property
|
|
def pod_selector(self):
|
|
"""Gets the pod_selector of this V1NetworkPolicySpec. # noqa: E501
|
|
|
|
|
|
:return: The pod_selector of this V1NetworkPolicySpec. # noqa: E501
|
|
:rtype: V1LabelSelector
|
|
"""
|
|
return self._pod_selector
|
|
|
|
@pod_selector.setter
|
|
def pod_selector(self, pod_selector):
|
|
"""Sets the pod_selector of this V1NetworkPolicySpec.
|
|
|
|
|
|
:param pod_selector: The pod_selector of this V1NetworkPolicySpec. # noqa: E501
|
|
:type: V1LabelSelector
|
|
"""
|
|
if self.local_vars_configuration.client_side_validation and pod_selector is None: # noqa: E501
|
|
raise ValueError("Invalid value for `pod_selector`, must not be `None`") # noqa: E501
|
|
|
|
self._pod_selector = pod_selector
|
|
|
|
@property
|
|
def policy_types(self):
|
|
"""Gets the policy_types of this V1NetworkPolicySpec. # noqa: E501
|
|
|
|
policyTypes is a list of rule types that the NetworkPolicy relates to. Valid options are [\"Ingress\"], [\"Egress\"], or [\"Ingress\", \"Egress\"]. If this field is not specified, it will default based on the existence of ingress or egress rules; policies that contain an egress section are assumed to affect egress, and all policies (whether or not they contain an ingress section) are assumed to affect ingress. If you want to write an egress-only policy, you must explicitly specify policyTypes [ \"Egress\" ]. Likewise, if you want to write a policy that specifies that no egress is allowed, you must specify a policyTypes value that include \"Egress\" (since such a policy would not include an egress section and would otherwise default to just [ \"Ingress\" ]). This field is beta-level in 1.8 # noqa: E501
|
|
|
|
:return: The policy_types of this V1NetworkPolicySpec. # noqa: E501
|
|
:rtype: list[str]
|
|
"""
|
|
return self._policy_types
|
|
|
|
@policy_types.setter
|
|
def policy_types(self, policy_types):
|
|
"""Sets the policy_types of this V1NetworkPolicySpec.
|
|
|
|
policyTypes is a list of rule types that the NetworkPolicy relates to. Valid options are [\"Ingress\"], [\"Egress\"], or [\"Ingress\", \"Egress\"]. If this field is not specified, it will default based on the existence of ingress or egress rules; policies that contain an egress section are assumed to affect egress, and all policies (whether or not they contain an ingress section) are assumed to affect ingress. If you want to write an egress-only policy, you must explicitly specify policyTypes [ \"Egress\" ]. Likewise, if you want to write a policy that specifies that no egress is allowed, you must specify a policyTypes value that include \"Egress\" (since such a policy would not include an egress section and would otherwise default to just [ \"Ingress\" ]). This field is beta-level in 1.8 # noqa: E501
|
|
|
|
:param policy_types: The policy_types of this V1NetworkPolicySpec. # noqa: E501
|
|
:type: list[str]
|
|
"""
|
|
|
|
self._policy_types = policy_types
|
|
|
|
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, V1NetworkPolicySpec):
|
|
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, V1NetworkPolicySpec):
|
|
return True
|
|
|
|
return self.to_dict() != other.to_dict()
|