2019-06-13 15:43:57 +00:00
|
|
|
"""Alexa related errors."""
|
|
|
|
from homeassistant.exceptions import HomeAssistantError
|
|
|
|
|
|
|
|
from .const import API_TEMP_UNITS
|
|
|
|
|
|
|
|
|
|
|
|
class UnsupportedInterface(HomeAssistantError):
|
|
|
|
"""This entity does not support the requested Smart Home API interface."""
|
|
|
|
|
|
|
|
|
|
|
|
class UnsupportedProperty(HomeAssistantError):
|
|
|
|
"""This entity does not support the requested Smart Home API property."""
|
|
|
|
|
|
|
|
|
2019-06-19 08:06:29 +00:00
|
|
|
class NoTokenAvailable(HomeAssistantError):
|
|
|
|
"""There is no access token available."""
|
|
|
|
|
|
|
|
|
2019-06-13 15:43:57 +00:00
|
|
|
class AlexaError(Exception):
|
2019-06-19 08:06:29 +00:00
|
|
|
"""Base class for errors that can be serialized for the Alexa API.
|
2019-06-13 15:43:57 +00:00
|
|
|
|
|
|
|
A handler can raise subclasses of this to return an error to the request.
|
|
|
|
"""
|
|
|
|
|
|
|
|
namespace = None
|
|
|
|
error_type = None
|
|
|
|
|
|
|
|
def __init__(self, error_message, payload=None):
|
|
|
|
"""Initialize an alexa error."""
|
|
|
|
Exception.__init__(self)
|
|
|
|
self.error_message = error_message
|
|
|
|
self.payload = None
|
|
|
|
|
|
|
|
|
|
|
|
class AlexaInvalidEndpointError(AlexaError):
|
|
|
|
"""The endpoint in the request does not exist."""
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "NO_SUCH_ENDPOINT"
|
2019-06-13 15:43:57 +00:00
|
|
|
|
|
|
|
def __init__(self, endpoint_id):
|
|
|
|
"""Initialize invalid endpoint error."""
|
2019-09-03 14:11:36 +00:00
|
|
|
msg = f"The endpoint {endpoint_id} does not exist"
|
2019-06-13 15:43:57 +00:00
|
|
|
AlexaError.__init__(self, msg)
|
|
|
|
self.endpoint_id = endpoint_id
|
|
|
|
|
|
|
|
|
|
|
|
class AlexaInvalidValueError(AlexaError):
|
|
|
|
"""Class to represent InvalidValue errors."""
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "INVALID_VALUE"
|
2019-06-13 15:43:57 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AlexaUnsupportedThermostatModeError(AlexaError):
|
|
|
|
"""Class to represent UnsupportedThermostatMode errors."""
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
namespace = "Alexa.ThermostatController"
|
|
|
|
error_type = "UNSUPPORTED_THERMOSTAT_MODE"
|
2019-06-13 15:43:57 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AlexaTempRangeError(AlexaError):
|
|
|
|
"""Class to represent TempRange errors."""
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "TEMPERATURE_VALUE_OUT_OF_RANGE"
|
2019-06-13 15:43:57 +00:00
|
|
|
|
|
|
|
def __init__(self, hass, temp, min_temp, max_temp):
|
|
|
|
"""Initialize TempRange error."""
|
|
|
|
unit = hass.config.units.temperature_unit
|
|
|
|
temp_range = {
|
2019-07-31 19:25:30 +00:00
|
|
|
"minimumValue": {"value": min_temp, "scale": API_TEMP_UNITS[unit]},
|
|
|
|
"maximumValue": {"value": max_temp, "scale": API_TEMP_UNITS[unit]},
|
2019-06-13 15:43:57 +00:00
|
|
|
}
|
2019-07-31 19:25:30 +00:00
|
|
|
payload = {"validRange": temp_range}
|
2019-09-03 14:11:36 +00:00
|
|
|
msg = f"The requested temperature {temp} is out of range"
|
2019-06-13 15:43:57 +00:00
|
|
|
|
|
|
|
AlexaError.__init__(self, msg, payload)
|
|
|
|
|
|
|
|
|
|
|
|
class AlexaBridgeUnreachableError(AlexaError):
|
|
|
|
"""Class to represent BridgeUnreachable errors."""
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "BRIDGE_UNREACHABLE"
|
2019-10-04 15:41:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AlexaSecurityPanelUnauthorizedError(AlexaError):
|
|
|
|
"""Class to represent SecurityPanelController Unauthorized errors."""
|
|
|
|
|
|
|
|
namespace = "Alexa.SecurityPanelController"
|
|
|
|
error_type = "UNAUTHORIZED"
|
|
|
|
|
|
|
|
|
|
|
|
class AlexaSecurityPanelAuthorizationRequired(AlexaError):
|
|
|
|
"""Class to represent SecurityPanelController AuthorizationRequired errors."""
|
|
|
|
|
|
|
|
namespace = "Alexa.SecurityPanelController"
|
|
|
|
error_type = "AUTHORIZATION_REQUIRED"
|