159 lines
5.4 KiB
Python
159 lines
5.4 KiB
Python
|
"""
|
||
|
Garage Administration API v0+garage-v0.7.3
|
||
|
|
||
|
Administrate your Garage cluster programatically, including status, layout, keys, buckets, and maintainance tasks. *Disclaimer: The API is not stable yet, hence its v0 tag. The API can change at any time, and changes can include breaking backward compatibility. Read the changelog and upgrade your scripts before upgrading. Additionnaly, this specification is very early stage and can contain bugs, especially on error return codes/types that are not tested yet. Do not expect a well finished and polished product!* # noqa: E501
|
||
|
|
||
|
The version of the OpenAPI document: v0.7.3
|
||
|
Generated by: https://openapi-generator.tech
|
||
|
"""
|
||
|
|
||
|
|
||
|
class OpenApiException(Exception):
|
||
|
"""The base exception class for all OpenAPIExceptions"""
|
||
|
|
||
|
|
||
|
class ApiTypeError(OpenApiException, TypeError):
|
||
|
def __init__(self, msg, path_to_item=None, valid_classes=None,
|
||
|
key_type=None):
|
||
|
""" Raises an exception for TypeErrors
|
||
|
|
||
|
Args:
|
||
|
msg (str): the exception message
|
||
|
|
||
|
Keyword Args:
|
||
|
path_to_item (list): a list of keys an indices to get to the
|
||
|
current_item
|
||
|
None if unset
|
||
|
valid_classes (tuple): the primitive classes that current item
|
||
|
should be an instance of
|
||
|
None if unset
|
||
|
key_type (bool): False if our value is a value in a dict
|
||
|
True if it is a key in a dict
|
||
|
False if our item is an item in a list
|
||
|
None if unset
|
||
|
"""
|
||
|
self.path_to_item = path_to_item
|
||
|
self.valid_classes = valid_classes
|
||
|
self.key_type = key_type
|
||
|
full_msg = msg
|
||
|
if path_to_item:
|
||
|
full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
|
||
|
super(ApiTypeError, self).__init__(full_msg)
|
||
|
|
||
|
|
||
|
class ApiValueError(OpenApiException, ValueError):
|
||
|
def __init__(self, msg, path_to_item=None):
|
||
|
"""
|
||
|
Args:
|
||
|
msg (str): the exception message
|
||
|
|
||
|
Keyword Args:
|
||
|
path_to_item (list) the path to the exception in the
|
||
|
received_data dict. None if unset
|
||
|
"""
|
||
|
|
||
|
self.path_to_item = path_to_item
|
||
|
full_msg = msg
|
||
|
if path_to_item:
|
||
|
full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
|
||
|
super(ApiValueError, self).__init__(full_msg)
|
||
|
|
||
|
|
||
|
class ApiAttributeError(OpenApiException, AttributeError):
|
||
|
def __init__(self, msg, path_to_item=None):
|
||
|
"""
|
||
|
Raised when an attribute reference or assignment fails.
|
||
|
|
||
|
Args:
|
||
|
msg (str): the exception message
|
||
|
|
||
|
Keyword Args:
|
||
|
path_to_item (None/list) the path to the exception in the
|
||
|
received_data dict
|
||
|
"""
|
||
|
self.path_to_item = path_to_item
|
||
|
full_msg = msg
|
||
|
if path_to_item:
|
||
|
full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
|
||
|
super(ApiAttributeError, self).__init__(full_msg)
|
||
|
|
||
|
|
||
|
class ApiKeyError(OpenApiException, KeyError):
|
||
|
def __init__(self, msg, path_to_item=None):
|
||
|
"""
|
||
|
Args:
|
||
|
msg (str): the exception message
|
||
|
|
||
|
Keyword Args:
|
||
|
path_to_item (None/list) the path to the exception in the
|
||
|
received_data dict
|
||
|
"""
|
||
|
self.path_to_item = path_to_item
|
||
|
full_msg = msg
|
||
|
if path_to_item:
|
||
|
full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
|
||
|
super(ApiKeyError, self).__init__(full_msg)
|
||
|
|
||
|
|
||
|
class ApiException(OpenApiException):
|
||
|
|
||
|
def __init__(self, status=None, reason=None, http_resp=None):
|
||
|
if http_resp:
|
||
|
self.status = http_resp.status
|
||
|
self.reason = http_resp.reason
|
||
|
self.body = http_resp.data
|
||
|
self.headers = http_resp.getheaders()
|
||
|
else:
|
||
|
self.status = status
|
||
|
self.reason = reason
|
||
|
self.body = None
|
||
|
self.headers = None
|
||
|
|
||
|
def __str__(self):
|
||
|
"""Custom error messages for exception"""
|
||
|
error_message = "Status Code: {0}\n"\
|
||
|
"Reason: {1}\n".format(self.status, self.reason)
|
||
|
if self.headers:
|
||
|
error_message += "HTTP response headers: {0}\n".format(
|
||
|
self.headers)
|
||
|
|
||
|
if self.body:
|
||
|
error_message += "HTTP response body: {0}\n".format(self.body)
|
||
|
|
||
|
return error_message
|
||
|
|
||
|
|
||
|
class NotFoundException(ApiException):
|
||
|
|
||
|
def __init__(self, status=None, reason=None, http_resp=None):
|
||
|
super(NotFoundException, self).__init__(status, reason, http_resp)
|
||
|
|
||
|
|
||
|
class UnauthorizedException(ApiException):
|
||
|
|
||
|
def __init__(self, status=None, reason=None, http_resp=None):
|
||
|
super(UnauthorizedException, self).__init__(status, reason, http_resp)
|
||
|
|
||
|
|
||
|
class ForbiddenException(ApiException):
|
||
|
|
||
|
def __init__(self, status=None, reason=None, http_resp=None):
|
||
|
super(ForbiddenException, self).__init__(status, reason, http_resp)
|
||
|
|
||
|
|
||
|
class ServiceException(ApiException):
|
||
|
|
||
|
def __init__(self, status=None, reason=None, http_resp=None):
|
||
|
super(ServiceException, self).__init__(status, reason, http_resp)
|
||
|
|
||
|
|
||
|
def render_path(path_to_item):
|
||
|
"""Returns a string representation of a path"""
|
||
|
result = ""
|
||
|
for pth in path_to_item:
|
||
|
if isinstance(pth, int):
|
||
|
result += "[{0}]".format(pth)
|
||
|
else:
|
||
|
result += "['{0}']".format(pth)
|
||
|
return result
|