Source code for highspot.errors.exceptions

# -*- coding: utf-8 -*-
"""
:Module:            highspot.errors.exceptions
:Synopsis:          Collection of exception classes relating to the highspot library
:Created By:        Jeff Shurtliff
:Last Modified:     Jeff Shurtliff
:Modified Date:     16 Oct 2022
"""

#################
# Base Exception
#################


# Define base exception class
[docs]class HighspotError(Exception): """This is the base class for Highspot exceptions.""" pass
############################ # Authentication Exceptions ############################
[docs]class MissingAuthDataError(HighspotError): """This exception is used when authentication data is not supplied and therefore a connection cannot occur.""" def __init__(self, *args, **kwargs): """This method defines the default or custom message for the exception.""" default_msg = "The authentication data was not provided and a connection cannot be established." if not (args or kwargs): args = (default_msg,) else: custom_msg = f'The {args[0]} {default_msg.split("data ")[1]}' args = (custom_msg,) super().__init__(*args)
##################### # General Exceptions #####################
[docs]class CurrentlyUnsupportedError(HighspotError): """This exception is used when a feature or functionality being used is currently unsupported.""" def __init__(self, *args, **kwargs): """This method defines the default or custom message for the exception.""" default_msg = "This feature is currently unsupported at this time." if not (args or kwargs): args = (default_msg,) else: custom_msg = f"The '{args[0]}' {default_msg.split('This ')[1]}" args = (custom_msg,) super().__init__(*args)
[docs]class DataMismatchError(HighspotError): """This exception is used when there is a mismatch between two data sources.""" def __init__(self, *args, **kwargs): """This method defines the default or custom message for the exception.""" default_msg = "A data mismatch was found with the data sources." if not (args or kwargs): args = (default_msg,) elif 'data' in kwargs: multi_types = [list, tuple, set] if type(kwargs['data']) == str: custom_msg = f"{default_msg.split('data')[0]}'{kwargs['val']}'{default_msg.split('with the')[1]}" custom_msg = custom_msg.replace('sources', 'source') args = (custom_msg,) elif type(kwargs['data']) in multi_types and len(kwargs['data']) == 2: custom_section = f"'{kwargs['data'][0]}' and '{kwargs['data'][1]}'" custom_msg = f"{default_msg.split('data sources')[0]}{custom_section}{default_msg.split('with the')[1]}" args = (custom_msg,) super().__init__(*args)
[docs]class InvalidFieldError(HighspotError): """This exception is used when an invalid field is provided.""" def __init__(self, *args, **kwargs): """This method defines the default or custom message for the exception.""" default_msg = "The field that was provided is invalid." if not (args or kwargs): args = (default_msg,) elif 'val' in kwargs: custom_msg = f"{default_msg.split('field ')[0]}'{kwargs['val']}'{default_msg.split('The')[1]}" args = (custom_msg,) super().__init__(*args)
[docs]class MissingRequiredDataError(HighspotError): """This exception is used when a function or method is missing one or more required arguments.""" def __init__(self, *args, **kwargs): """This method defines the default or custom message for the exception.""" default_msg = "Missing one or more required parameters" init_msg = "The object failed to initialize as it is missing one or more required arguments." param_msg = "The required parameter 'PARAMETER_NAME' is not defined" if not (args or kwargs): args = (default_msg,) elif 'init' in args or 'initialize' in args: if 'object' in kwargs: custom_msg = f"{init_msg.split('object')[0]}'{kwargs['object']}'{init_msg.split('The')[1]}" args = (custom_msg,) else: args = (init_msg,) elif 'param' in kwargs: args = (param_msg.replace('PARAMETER_NAME', kwargs['param']),) else: args = (default_msg,) super().__init__(*args)
######################### # Generic API Exceptions #########################
[docs]class APIConnectionError(HighspotError): """This exception is used when the API query could not be completed due to connection aborts and/or timeouts.""" def __init__(self, *args, **kwargs): """This method defines the default or custom message for the exception.""" default_msg = "The API query could not be completed due to connection aborts and/or timeouts." if not (args or kwargs): args = (default_msg,) super().__init__(*args)
[docs]class APIRequestError(HighspotError): """This exception is used for generic API request errors when there isn't a more specific exception.""" def __init__(self, *args, **kwargs): """This method defines the default or custom message for the exception.""" default_msg = "The API request did not return a successful response." if not (args or kwargs): args = (default_msg,) super().__init__(*args)