2019-06-13 15:43:57 +00:00
|
|
|
"""Alexa related errors."""
|
2021-08-10 08:46:33 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2022-01-31 23:01:46 +00:00
|
|
|
from typing import Literal
|
|
|
|
|
2019-06-13 15:43:57 +00:00
|
|
|
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."""
|
|
|
|
|
|
|
|
|
2022-01-13 17:47:31 +00:00
|
|
|
class RequireRelink(Exception):
|
|
|
|
"""The skill needs to be relinked."""
|
|
|
|
|
|
|
|
|
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.
|
|
|
|
"""
|
|
|
|
|
2021-08-10 08:46:33 +00:00
|
|
|
namespace: str | None = None
|
|
|
|
error_type: str | None = None
|
2019-06-13 15:43:57 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
2022-01-31 23:01:46 +00:00
|
|
|
class AlexaInteralError(AlexaError):
|
|
|
|
"""Class to represent internal errors."""
|
|
|
|
|
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "INTERNAL_ERROR"
|
|
|
|
|
|
|
|
|
|
|
|
class AlexaNotSupportedInCurrentMode(AlexaError):
|
|
|
|
"""The device is not in the correct mode to support this command."""
|
|
|
|
|
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "NOT_SUPPORTED_IN_CURRENT_MODE"
|
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
endpoint_id: str,
|
|
|
|
current_mode: Literal["COLOR", "ASLEEP", "NOT_PROVISIONED", "OTHER"],
|
|
|
|
) -> None:
|
|
|
|
"""Initialize invalid endpoint error."""
|
|
|
|
msg = f"Not supported while in {current_mode} mode"
|
|
|
|
AlexaError.__init__(self, msg, {"currentDeviceMode": current_mode})
|
|
|
|
self.endpoint_id = endpoint_id
|
|
|
|
|
|
|
|
|
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"
|
2019-10-23 05:01:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AlexaAlreadyInOperationError(AlexaError):
|
|
|
|
"""Class to represent AlreadyInOperation errors."""
|
|
|
|
|
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "ALREADY_IN_OPERATION"
|
|
|
|
|
|
|
|
|
|
|
|
class AlexaInvalidDirectiveError(AlexaError):
|
|
|
|
"""Class to represent InvalidDirective errors."""
|
|
|
|
|
|
|
|
namespace = "Alexa"
|
|
|
|
error_type = "INVALID_DIRECTIVE"
|
2019-10-31 09:38:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AlexaVideoActionNotPermittedForContentError(AlexaError):
|
|
|
|
"""Class to represent action not permitted for content errors."""
|
|
|
|
|
|
|
|
namespace = "Alexa.Video"
|
|
|
|
error_type = "ACTION_NOT_PERMITTED_FOR_CONTENT"
|