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_http_ingress_path.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

178 lines
7.3 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 V1HTTPIngressPath(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 = {
'backend': 'V1IngressBackend',
'path': 'str',
'path_type': 'str'
}
attribute_map = {
'backend': 'backend',
'path': 'path',
'path_type': 'pathType'
}
def __init__(self, backend=None, path=None, path_type=None, local_vars_configuration=None): # noqa: E501
"""V1HTTPIngressPath - 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._backend = None
self._path = None
self._path_type = None
self.discriminator = None
self.backend = backend
if path is not None:
self.path = path
self.path_type = path_type
@property
def backend(self):
"""Gets the backend of this V1HTTPIngressPath. # noqa: E501
:return: The backend of this V1HTTPIngressPath. # noqa: E501
:rtype: V1IngressBackend
"""
return self._backend
@backend.setter
def backend(self, backend):
"""Sets the backend of this V1HTTPIngressPath.
:param backend: The backend of this V1HTTPIngressPath. # noqa: E501
:type: V1IngressBackend
"""
if self.local_vars_configuration.client_side_validation and backend is None: # noqa: E501
raise ValueError("Invalid value for `backend`, must not be `None`") # noqa: E501
self._backend = backend
@property
def path(self):
"""Gets the path of this V1HTTPIngressPath. # noqa: E501
path is matched against the path of an incoming request. Currently it can contain characters disallowed from the conventional \"path\" part of a URL as defined by RFC 3986. Paths must begin with a '/' and must be present when using PathType with value \"Exact\" or \"Prefix\". # noqa: E501
:return: The path of this V1HTTPIngressPath. # noqa: E501
:rtype: str
"""
return self._path
@path.setter
def path(self, path):
"""Sets the path of this V1HTTPIngressPath.
path is matched against the path of an incoming request. Currently it can contain characters disallowed from the conventional \"path\" part of a URL as defined by RFC 3986. Paths must begin with a '/' and must be present when using PathType with value \"Exact\" or \"Prefix\". # noqa: E501
:param path: The path of this V1HTTPIngressPath. # noqa: E501
:type: str
"""
self._path = path
@property
def path_type(self):
"""Gets the path_type of this V1HTTPIngressPath. # noqa: E501
pathType determines the interpretation of the path matching. PathType can be one of the following values: * Exact: Matches the URL path exactly. * Prefix: Matches based on a URL path prefix split by '/'. Matching is done on a path element by element basis. A path element refers is the list of labels in the path split by the '/' separator. A request is a match for path p if every p is an element-wise prefix of p of the request path. Note that if the last element of the path is a substring of the last element in request path, it is not a match (e.g. /foo/bar matches /foo/bar/baz, but does not match /foo/barbaz). * ImplementationSpecific: Interpretation of the Path matching is up to the IngressClass. Implementations can treat this as a separate PathType or treat it identically to Prefix or Exact path types. Implementations are required to support all path types. # noqa: E501
:return: The path_type of this V1HTTPIngressPath. # noqa: E501
:rtype: str
"""
return self._path_type
@path_type.setter
def path_type(self, path_type):
"""Sets the path_type of this V1HTTPIngressPath.
pathType determines the interpretation of the path matching. PathType can be one of the following values: * Exact: Matches the URL path exactly. * Prefix: Matches based on a URL path prefix split by '/'. Matching is done on a path element by element basis. A path element refers is the list of labels in the path split by the '/' separator. A request is a match for path p if every p is an element-wise prefix of p of the request path. Note that if the last element of the path is a substring of the last element in request path, it is not a match (e.g. /foo/bar matches /foo/bar/baz, but does not match /foo/barbaz). * ImplementationSpecific: Interpretation of the Path matching is up to the IngressClass. Implementations can treat this as a separate PathType or treat it identically to Prefix or Exact path types. Implementations are required to support all path types. # noqa: E501
:param path_type: The path_type of this V1HTTPIngressPath. # noqa: E501
:type: str
"""
if self.local_vars_configuration.client_side_validation and path_type is None: # noqa: E501
raise ValueError("Invalid value for `path_type`, must not be `None`") # noqa: E501
self._path_type = path_type
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, V1HTTPIngressPath):
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, V1HTTPIngressPath):
return True
return self.to_dict() != other.to_dict()