This repository has been archived on 2025-01-23. You can view files and clone it, but cannot push or open issues or pull requests.
traefik-certmanager/kubernetes/client/models/v1_persistent_volume_claim_status.py
Tom Neuber 9129813244
All checks were successful
ci/woodpecker/push/build Pipeline was successful
ci/woodpecker/push/deploy Pipeline was successful
fix(kubernetes): temporary solution for updated k8s python client
2025-01-05 00:33:58 +01:00

316 lines
18 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 V1PersistentVolumeClaimStatus(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 = {
'access_modes': 'list[str]',
'allocated_resource_statuses': 'dict(str, str)',
'allocated_resources': 'dict(str, str)',
'capacity': 'dict(str, str)',
'conditions': 'list[V1PersistentVolumeClaimCondition]',
'current_volume_attributes_class_name': 'str',
'modify_volume_status': 'V1ModifyVolumeStatus',
'phase': 'str'
}
attribute_map = {
'access_modes': 'accessModes',
'allocated_resource_statuses': 'allocatedResourceStatuses',
'allocated_resources': 'allocatedResources',
'capacity': 'capacity',
'conditions': 'conditions',
'current_volume_attributes_class_name': 'currentVolumeAttributesClassName',
'modify_volume_status': 'modifyVolumeStatus',
'phase': 'phase'
}
def __init__(self, access_modes=None, allocated_resource_statuses=None, allocated_resources=None, capacity=None, conditions=None, current_volume_attributes_class_name=None, modify_volume_status=None, phase=None, local_vars_configuration=None): # noqa: E501
"""V1PersistentVolumeClaimStatus - 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._access_modes = None
self._allocated_resource_statuses = None
self._allocated_resources = None
self._capacity = None
self._conditions = None
self._current_volume_attributes_class_name = None
self._modify_volume_status = None
self._phase = None
self.discriminator = None
if access_modes is not None:
self.access_modes = access_modes
if allocated_resource_statuses is not None:
self.allocated_resource_statuses = allocated_resource_statuses
if allocated_resources is not None:
self.allocated_resources = allocated_resources
if capacity is not None:
self.capacity = capacity
if conditions is not None:
self.conditions = conditions
if current_volume_attributes_class_name is not None:
self.current_volume_attributes_class_name = current_volume_attributes_class_name
if modify_volume_status is not None:
self.modify_volume_status = modify_volume_status
if phase is not None:
self.phase = phase
@property
def access_modes(self):
"""Gets the access_modes of this V1PersistentVolumeClaimStatus. # noqa: E501
accessModes contains the actual access modes the volume backing the PVC has. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#access-modes-1 # noqa: E501
:return: The access_modes of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: list[str]
"""
return self._access_modes
@access_modes.setter
def access_modes(self, access_modes):
"""Sets the access_modes of this V1PersistentVolumeClaimStatus.
accessModes contains the actual access modes the volume backing the PVC has. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#access-modes-1 # noqa: E501
:param access_modes: The access_modes of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: list[str]
"""
self._access_modes = access_modes
@property
def allocated_resource_statuses(self):
"""Gets the allocated_resource_statuses of this V1PersistentVolumeClaimStatus. # noqa: E501
allocatedResourceStatuses stores status of resource being resized for the given PVC. Key names follow standard Kubernetes label syntax. Valid values are either: * Un-prefixed keys: - storage - the capacity of the volume. * Custom resources must use implementation-defined prefixed names such as \"example.com/my-custom-resource\" Apart from above values - keys that are unprefixed or have kubernetes.io prefix are considered reserved and hence may not be used. ClaimResourceStatus can be in any of following states: - ControllerResizeInProgress: State set when resize controller starts resizing the volume in control-plane. - ControllerResizeFailed: State set when resize has failed in resize controller with a terminal error. - NodeResizePending: State set when resize controller has finished resizing the volume but further resizing of volume is needed on the node. - NodeResizeInProgress: State set when kubelet starts resizing the volume. - NodeResizeFailed: State set when resizing has failed in kubelet with a terminal error. Transient errors don't set NodeResizeFailed. For example: if expanding a PVC for more capacity - this field can be one of the following states: - pvc.status.allocatedResourceStatus['storage'] = \"ControllerResizeInProgress\" - pvc.status.allocatedResourceStatus['storage'] = \"ControllerResizeFailed\" - pvc.status.allocatedResourceStatus['storage'] = \"NodeResizePending\" - pvc.status.allocatedResourceStatus['storage'] = \"NodeResizeInProgress\" - pvc.status.allocatedResourceStatus['storage'] = \"NodeResizeFailed\" When this field is not set, it means that no resize operation is in progress for the given PVC. A controller that receives PVC update with previously unknown resourceName or ClaimResourceStatus should ignore the update for the purpose it was designed. For example - a controller that only is responsible for resizing capacity of the volume, should ignore PVC updates that change other valid resources associated with PVC. This is an alpha field and requires enabling RecoverVolumeExpansionFailure feature. # noqa: E501
:return: The allocated_resource_statuses of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: dict(str, str)
"""
return self._allocated_resource_statuses
@allocated_resource_statuses.setter
def allocated_resource_statuses(self, allocated_resource_statuses):
"""Sets the allocated_resource_statuses of this V1PersistentVolumeClaimStatus.
allocatedResourceStatuses stores status of resource being resized for the given PVC. Key names follow standard Kubernetes label syntax. Valid values are either: * Un-prefixed keys: - storage - the capacity of the volume. * Custom resources must use implementation-defined prefixed names such as \"example.com/my-custom-resource\" Apart from above values - keys that are unprefixed or have kubernetes.io prefix are considered reserved and hence may not be used. ClaimResourceStatus can be in any of following states: - ControllerResizeInProgress: State set when resize controller starts resizing the volume in control-plane. - ControllerResizeFailed: State set when resize has failed in resize controller with a terminal error. - NodeResizePending: State set when resize controller has finished resizing the volume but further resizing of volume is needed on the node. - NodeResizeInProgress: State set when kubelet starts resizing the volume. - NodeResizeFailed: State set when resizing has failed in kubelet with a terminal error. Transient errors don't set NodeResizeFailed. For example: if expanding a PVC for more capacity - this field can be one of the following states: - pvc.status.allocatedResourceStatus['storage'] = \"ControllerResizeInProgress\" - pvc.status.allocatedResourceStatus['storage'] = \"ControllerResizeFailed\" - pvc.status.allocatedResourceStatus['storage'] = \"NodeResizePending\" - pvc.status.allocatedResourceStatus['storage'] = \"NodeResizeInProgress\" - pvc.status.allocatedResourceStatus['storage'] = \"NodeResizeFailed\" When this field is not set, it means that no resize operation is in progress for the given PVC. A controller that receives PVC update with previously unknown resourceName or ClaimResourceStatus should ignore the update for the purpose it was designed. For example - a controller that only is responsible for resizing capacity of the volume, should ignore PVC updates that change other valid resources associated with PVC. This is an alpha field and requires enabling RecoverVolumeExpansionFailure feature. # noqa: E501
:param allocated_resource_statuses: The allocated_resource_statuses of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: dict(str, str)
"""
self._allocated_resource_statuses = allocated_resource_statuses
@property
def allocated_resources(self):
"""Gets the allocated_resources of this V1PersistentVolumeClaimStatus. # noqa: E501
allocatedResources tracks the resources allocated to a PVC including its capacity. Key names follow standard Kubernetes label syntax. Valid values are either: * Un-prefixed keys: - storage - the capacity of the volume. * Custom resources must use implementation-defined prefixed names such as \"example.com/my-custom-resource\" Apart from above values - keys that are unprefixed or have kubernetes.io prefix are considered reserved and hence may not be used. Capacity reported here may be larger than the actual capacity when a volume expansion operation is requested. For storage quota, the larger value from allocatedResources and PVC.spec.resources is used. If allocatedResources is not set, PVC.spec.resources alone is used for quota calculation. If a volume expansion capacity request is lowered, allocatedResources is only lowered if there are no expansion operations in progress and if the actual volume capacity is equal or lower than the requested capacity. A controller that receives PVC update with previously unknown resourceName should ignore the update for the purpose it was designed. For example - a controller that only is responsible for resizing capacity of the volume, should ignore PVC updates that change other valid resources associated with PVC. This is an alpha field and requires enabling RecoverVolumeExpansionFailure feature. # noqa: E501
:return: The allocated_resources of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: dict(str, str)
"""
return self._allocated_resources
@allocated_resources.setter
def allocated_resources(self, allocated_resources):
"""Sets the allocated_resources of this V1PersistentVolumeClaimStatus.
allocatedResources tracks the resources allocated to a PVC including its capacity. Key names follow standard Kubernetes label syntax. Valid values are either: * Un-prefixed keys: - storage - the capacity of the volume. * Custom resources must use implementation-defined prefixed names such as \"example.com/my-custom-resource\" Apart from above values - keys that are unprefixed or have kubernetes.io prefix are considered reserved and hence may not be used. Capacity reported here may be larger than the actual capacity when a volume expansion operation is requested. For storage quota, the larger value from allocatedResources and PVC.spec.resources is used. If allocatedResources is not set, PVC.spec.resources alone is used for quota calculation. If a volume expansion capacity request is lowered, allocatedResources is only lowered if there are no expansion operations in progress and if the actual volume capacity is equal or lower than the requested capacity. A controller that receives PVC update with previously unknown resourceName should ignore the update for the purpose it was designed. For example - a controller that only is responsible for resizing capacity of the volume, should ignore PVC updates that change other valid resources associated with PVC. This is an alpha field and requires enabling RecoverVolumeExpansionFailure feature. # noqa: E501
:param allocated_resources: The allocated_resources of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: dict(str, str)
"""
self._allocated_resources = allocated_resources
@property
def capacity(self):
"""Gets the capacity of this V1PersistentVolumeClaimStatus. # noqa: E501
capacity represents the actual resources of the underlying volume. # noqa: E501
:return: The capacity of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: dict(str, str)
"""
return self._capacity
@capacity.setter
def capacity(self, capacity):
"""Sets the capacity of this V1PersistentVolumeClaimStatus.
capacity represents the actual resources of the underlying volume. # noqa: E501
:param capacity: The capacity of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: dict(str, str)
"""
self._capacity = capacity
@property
def conditions(self):
"""Gets the conditions of this V1PersistentVolumeClaimStatus. # noqa: E501
conditions is the current Condition of persistent volume claim. If underlying persistent volume is being resized then the Condition will be set to 'Resizing'. # noqa: E501
:return: The conditions of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: list[V1PersistentVolumeClaimCondition]
"""
return self._conditions
@conditions.setter
def conditions(self, conditions):
"""Sets the conditions of this V1PersistentVolumeClaimStatus.
conditions is the current Condition of persistent volume claim. If underlying persistent volume is being resized then the Condition will be set to 'Resizing'. # noqa: E501
:param conditions: The conditions of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: list[V1PersistentVolumeClaimCondition]
"""
self._conditions = conditions
@property
def current_volume_attributes_class_name(self):
"""Gets the current_volume_attributes_class_name of this V1PersistentVolumeClaimStatus. # noqa: E501
currentVolumeAttributesClassName is the current name of the VolumeAttributesClass the PVC is using. When unset, there is no VolumeAttributeClass applied to this PersistentVolumeClaim This is a beta field and requires enabling VolumeAttributesClass feature (off by default). # noqa: E501
:return: The current_volume_attributes_class_name of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: str
"""
return self._current_volume_attributes_class_name
@current_volume_attributes_class_name.setter
def current_volume_attributes_class_name(self, current_volume_attributes_class_name):
"""Sets the current_volume_attributes_class_name of this V1PersistentVolumeClaimStatus.
currentVolumeAttributesClassName is the current name of the VolumeAttributesClass the PVC is using. When unset, there is no VolumeAttributeClass applied to this PersistentVolumeClaim This is a beta field and requires enabling VolumeAttributesClass feature (off by default). # noqa: E501
:param current_volume_attributes_class_name: The current_volume_attributes_class_name of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: str
"""
self._current_volume_attributes_class_name = current_volume_attributes_class_name
@property
def modify_volume_status(self):
"""Gets the modify_volume_status of this V1PersistentVolumeClaimStatus. # noqa: E501
:return: The modify_volume_status of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: V1ModifyVolumeStatus
"""
return self._modify_volume_status
@modify_volume_status.setter
def modify_volume_status(self, modify_volume_status):
"""Sets the modify_volume_status of this V1PersistentVolumeClaimStatus.
:param modify_volume_status: The modify_volume_status of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: V1ModifyVolumeStatus
"""
self._modify_volume_status = modify_volume_status
@property
def phase(self):
"""Gets the phase of this V1PersistentVolumeClaimStatus. # noqa: E501
phase represents the current phase of PersistentVolumeClaim. # noqa: E501
:return: The phase of this V1PersistentVolumeClaimStatus. # noqa: E501
:rtype: str
"""
return self._phase
@phase.setter
def phase(self, phase):
"""Sets the phase of this V1PersistentVolumeClaimStatus.
phase represents the current phase of PersistentVolumeClaim. # noqa: E501
:param phase: The phase of this V1PersistentVolumeClaimStatus. # noqa: E501
:type: str
"""
self._phase = phase
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, V1PersistentVolumeClaimStatus):
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, V1PersistentVolumeClaimStatus):
return True
return self.to_dict() != other.to_dict()