294 lines
14 KiB
Python
294 lines
14 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 V1PodDisruptionBudgetStatus(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 = {
|
|
'conditions': 'list[V1Condition]',
|
|
'current_healthy': 'int',
|
|
'desired_healthy': 'int',
|
|
'disrupted_pods': 'dict(str, datetime)',
|
|
'disruptions_allowed': 'int',
|
|
'expected_pods': 'int',
|
|
'observed_generation': 'int'
|
|
}
|
|
|
|
attribute_map = {
|
|
'conditions': 'conditions',
|
|
'current_healthy': 'currentHealthy',
|
|
'desired_healthy': 'desiredHealthy',
|
|
'disrupted_pods': 'disruptedPods',
|
|
'disruptions_allowed': 'disruptionsAllowed',
|
|
'expected_pods': 'expectedPods',
|
|
'observed_generation': 'observedGeneration'
|
|
}
|
|
|
|
def __init__(self, conditions=None, current_healthy=None, desired_healthy=None, disrupted_pods=None, disruptions_allowed=None, expected_pods=None, observed_generation=None, local_vars_configuration=None): # noqa: E501
|
|
"""V1PodDisruptionBudgetStatus - 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._conditions = None
|
|
self._current_healthy = None
|
|
self._desired_healthy = None
|
|
self._disrupted_pods = None
|
|
self._disruptions_allowed = None
|
|
self._expected_pods = None
|
|
self._observed_generation = None
|
|
self.discriminator = None
|
|
|
|
if conditions is not None:
|
|
self.conditions = conditions
|
|
self.current_healthy = current_healthy
|
|
self.desired_healthy = desired_healthy
|
|
if disrupted_pods is not None:
|
|
self.disrupted_pods = disrupted_pods
|
|
self.disruptions_allowed = disruptions_allowed
|
|
self.expected_pods = expected_pods
|
|
if observed_generation is not None:
|
|
self.observed_generation = observed_generation
|
|
|
|
@property
|
|
def conditions(self):
|
|
"""Gets the conditions of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
|
|
Conditions contain conditions for PDB. The disruption controller sets the DisruptionAllowed condition. The following are known values for the reason field (additional reasons could be added in the future): - SyncFailed: The controller encountered an error and wasn't able to compute the number of allowed disruptions. Therefore no disruptions are allowed and the status of the condition will be False. - InsufficientPods: The number of pods are either at or below the number required by the PodDisruptionBudget. No disruptions are allowed and the status of the condition will be False. - SufficientPods: There are more pods than required by the PodDisruptionBudget. The condition will be True, and the number of allowed disruptions are provided by the disruptionsAllowed property. # noqa: E501
|
|
|
|
:return: The conditions of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:rtype: list[V1Condition]
|
|
"""
|
|
return self._conditions
|
|
|
|
@conditions.setter
|
|
def conditions(self, conditions):
|
|
"""Sets the conditions of this V1PodDisruptionBudgetStatus.
|
|
|
|
Conditions contain conditions for PDB. The disruption controller sets the DisruptionAllowed condition. The following are known values for the reason field (additional reasons could be added in the future): - SyncFailed: The controller encountered an error and wasn't able to compute the number of allowed disruptions. Therefore no disruptions are allowed and the status of the condition will be False. - InsufficientPods: The number of pods are either at or below the number required by the PodDisruptionBudget. No disruptions are allowed and the status of the condition will be False. - SufficientPods: There are more pods than required by the PodDisruptionBudget. The condition will be True, and the number of allowed disruptions are provided by the disruptionsAllowed property. # noqa: E501
|
|
|
|
:param conditions: The conditions of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:type: list[V1Condition]
|
|
"""
|
|
|
|
self._conditions = conditions
|
|
|
|
@property
|
|
def current_healthy(self):
|
|
"""Gets the current_healthy of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
|
|
current number of healthy pods # noqa: E501
|
|
|
|
:return: The current_healthy of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:rtype: int
|
|
"""
|
|
return self._current_healthy
|
|
|
|
@current_healthy.setter
|
|
def current_healthy(self, current_healthy):
|
|
"""Sets the current_healthy of this V1PodDisruptionBudgetStatus.
|
|
|
|
current number of healthy pods # noqa: E501
|
|
|
|
:param current_healthy: The current_healthy of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:type: int
|
|
"""
|
|
if self.local_vars_configuration.client_side_validation and current_healthy is None: # noqa: E501
|
|
raise ValueError("Invalid value for `current_healthy`, must not be `None`") # noqa: E501
|
|
|
|
self._current_healthy = current_healthy
|
|
|
|
@property
|
|
def desired_healthy(self):
|
|
"""Gets the desired_healthy of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
|
|
minimum desired number of healthy pods # noqa: E501
|
|
|
|
:return: The desired_healthy of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:rtype: int
|
|
"""
|
|
return self._desired_healthy
|
|
|
|
@desired_healthy.setter
|
|
def desired_healthy(self, desired_healthy):
|
|
"""Sets the desired_healthy of this V1PodDisruptionBudgetStatus.
|
|
|
|
minimum desired number of healthy pods # noqa: E501
|
|
|
|
:param desired_healthy: The desired_healthy of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:type: int
|
|
"""
|
|
if self.local_vars_configuration.client_side_validation and desired_healthy is None: # noqa: E501
|
|
raise ValueError("Invalid value for `desired_healthy`, must not be `None`") # noqa: E501
|
|
|
|
self._desired_healthy = desired_healthy
|
|
|
|
@property
|
|
def disrupted_pods(self):
|
|
"""Gets the disrupted_pods of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
|
|
DisruptedPods contains information about pods whose eviction was processed by the API server eviction subresource handler but has not yet been observed by the PodDisruptionBudget controller. A pod will be in this map from the time when the API server processed the eviction request to the time when the pod is seen by PDB controller as having been marked for deletion (or after a timeout). The key in the map is the name of the pod and the value is the time when the API server processed the eviction request. If the deletion didn't occur and a pod is still there it will be removed from the list automatically by PodDisruptionBudget controller after some time. If everything goes smooth this map should be empty for the most of the time. Large number of entries in the map may indicate problems with pod deletions. # noqa: E501
|
|
|
|
:return: The disrupted_pods of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:rtype: dict(str, datetime)
|
|
"""
|
|
return self._disrupted_pods
|
|
|
|
@disrupted_pods.setter
|
|
def disrupted_pods(self, disrupted_pods):
|
|
"""Sets the disrupted_pods of this V1PodDisruptionBudgetStatus.
|
|
|
|
DisruptedPods contains information about pods whose eviction was processed by the API server eviction subresource handler but has not yet been observed by the PodDisruptionBudget controller. A pod will be in this map from the time when the API server processed the eviction request to the time when the pod is seen by PDB controller as having been marked for deletion (or after a timeout). The key in the map is the name of the pod and the value is the time when the API server processed the eviction request. If the deletion didn't occur and a pod is still there it will be removed from the list automatically by PodDisruptionBudget controller after some time. If everything goes smooth this map should be empty for the most of the time. Large number of entries in the map may indicate problems with pod deletions. # noqa: E501
|
|
|
|
:param disrupted_pods: The disrupted_pods of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:type: dict(str, datetime)
|
|
"""
|
|
|
|
self._disrupted_pods = disrupted_pods
|
|
|
|
@property
|
|
def disruptions_allowed(self):
|
|
"""Gets the disruptions_allowed of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
|
|
Number of pod disruptions that are currently allowed. # noqa: E501
|
|
|
|
:return: The disruptions_allowed of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:rtype: int
|
|
"""
|
|
return self._disruptions_allowed
|
|
|
|
@disruptions_allowed.setter
|
|
def disruptions_allowed(self, disruptions_allowed):
|
|
"""Sets the disruptions_allowed of this V1PodDisruptionBudgetStatus.
|
|
|
|
Number of pod disruptions that are currently allowed. # noqa: E501
|
|
|
|
:param disruptions_allowed: The disruptions_allowed of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:type: int
|
|
"""
|
|
if self.local_vars_configuration.client_side_validation and disruptions_allowed is None: # noqa: E501
|
|
raise ValueError("Invalid value for `disruptions_allowed`, must not be `None`") # noqa: E501
|
|
|
|
self._disruptions_allowed = disruptions_allowed
|
|
|
|
@property
|
|
def expected_pods(self):
|
|
"""Gets the expected_pods of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
|
|
total number of pods counted by this disruption budget # noqa: E501
|
|
|
|
:return: The expected_pods of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:rtype: int
|
|
"""
|
|
return self._expected_pods
|
|
|
|
@expected_pods.setter
|
|
def expected_pods(self, expected_pods):
|
|
"""Sets the expected_pods of this V1PodDisruptionBudgetStatus.
|
|
|
|
total number of pods counted by this disruption budget # noqa: E501
|
|
|
|
:param expected_pods: The expected_pods of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:type: int
|
|
"""
|
|
if self.local_vars_configuration.client_side_validation and expected_pods is None: # noqa: E501
|
|
raise ValueError("Invalid value for `expected_pods`, must not be `None`") # noqa: E501
|
|
|
|
self._expected_pods = expected_pods
|
|
|
|
@property
|
|
def observed_generation(self):
|
|
"""Gets the observed_generation of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
|
|
Most recent generation observed when updating this PDB status. DisruptionsAllowed and other status information is valid only if observedGeneration equals to PDB's object generation. # noqa: E501
|
|
|
|
:return: The observed_generation of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:rtype: int
|
|
"""
|
|
return self._observed_generation
|
|
|
|
@observed_generation.setter
|
|
def observed_generation(self, observed_generation):
|
|
"""Sets the observed_generation of this V1PodDisruptionBudgetStatus.
|
|
|
|
Most recent generation observed when updating this PDB status. DisruptionsAllowed and other status information is valid only if observedGeneration equals to PDB's object generation. # noqa: E501
|
|
|
|
:param observed_generation: The observed_generation of this V1PodDisruptionBudgetStatus. # noqa: E501
|
|
:type: int
|
|
"""
|
|
|
|
self._observed_generation = observed_generation
|
|
|
|
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, V1PodDisruptionBudgetStatus):
|
|
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, V1PodDisruptionBudgetStatus):
|
|
return True
|
|
|
|
return self.to_dict() != other.to_dict()
|