2017-07-07 06:21:06 +00:00
|
|
|
"""
|
|
|
|
Notifier for LaMetric time.
|
|
|
|
|
|
|
|
For more details about this platform, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/notify.lametric/
|
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
|
2018-03-23 17:10:52 +00:00
|
|
|
from requests.exceptions import ConnectionError as RequestsConnectionError
|
2017-07-07 06:21:06 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.components.notify import (
|
|
|
|
ATTR_TARGET, ATTR_DATA, PLATFORM_SCHEMA, BaseNotificationService)
|
|
|
|
from homeassistant.const import CONF_ICON
|
|
|
|
import homeassistant.helpers.config_validation as cv
|
|
|
|
|
2017-11-13 20:12:15 +00:00
|
|
|
from homeassistant.components.lametric import DOMAIN as LAMETRIC_DOMAIN
|
2017-07-07 06:21:06 +00:00
|
|
|
|
|
|
|
REQUIREMENTS = ['lmnotify==0.0.4']
|
2017-11-13 20:12:15 +00:00
|
|
|
DEPENDENCIES = ['lametric']
|
2017-07-07 06:21:06 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2017-11-18 20:12:16 +00:00
|
|
|
CONF_LIFETIME = "lifetime"
|
|
|
|
CONF_CYCLES = "cycles"
|
2017-07-07 06:21:06 +00:00
|
|
|
|
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
|
|
|
vol.Optional(CONF_ICON, default="i555"): cv.string,
|
2017-11-18 20:12:16 +00:00
|
|
|
vol.Optional(CONF_LIFETIME, default=10): cv.positive_int,
|
|
|
|
vol.Optional(CONF_CYCLES, default=1): cv.positive_int,
|
2017-07-07 06:21:06 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
# pylint: disable=unused-variable
|
|
|
|
def get_service(hass, config, discovery_info=None):
|
2017-11-18 20:12:16 +00:00
|
|
|
"""Get the LaMetric notification service."""
|
2017-11-13 20:12:15 +00:00
|
|
|
hlmn = hass.data.get(LAMETRIC_DOMAIN)
|
2017-07-07 06:21:06 +00:00
|
|
|
return LaMetricNotificationService(hlmn,
|
|
|
|
config[CONF_ICON],
|
2017-11-18 20:12:16 +00:00
|
|
|
config[CONF_LIFETIME] * 1000,
|
|
|
|
config[CONF_CYCLES])
|
2017-07-07 06:21:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LaMetricNotificationService(BaseNotificationService):
|
|
|
|
"""Implement the notification service for LaMetric."""
|
|
|
|
|
2017-11-18 20:12:16 +00:00
|
|
|
def __init__(self, hasslametricmanager, icon, lifetime, cycles):
|
2017-07-07 06:21:06 +00:00
|
|
|
"""Initialize the service."""
|
|
|
|
self.hasslametricmanager = hasslametricmanager
|
|
|
|
self._icon = icon
|
2017-11-18 20:12:16 +00:00
|
|
|
self._lifetime = lifetime
|
|
|
|
self._cycles = cycles
|
2018-03-23 17:10:52 +00:00
|
|
|
self._devices = []
|
2017-07-07 06:21:06 +00:00
|
|
|
|
|
|
|
# pylint: disable=broad-except
|
|
|
|
def send_message(self, message="", **kwargs):
|
2017-11-18 20:12:16 +00:00
|
|
|
"""Send a message to some LaMetric device."""
|
2017-07-07 06:21:06 +00:00
|
|
|
from lmnotify import SimpleFrame, Sound, Model
|
2017-11-13 20:12:15 +00:00
|
|
|
from oauthlib.oauth2 import TokenExpiredError
|
2017-07-07 06:21:06 +00:00
|
|
|
|
|
|
|
targets = kwargs.get(ATTR_TARGET)
|
|
|
|
data = kwargs.get(ATTR_DATA)
|
|
|
|
_LOGGER.debug("Targets/Data: %s/%s", targets, data)
|
|
|
|
icon = self._icon
|
2017-11-18 20:12:16 +00:00
|
|
|
cycles = self._cycles
|
2017-07-07 06:21:06 +00:00
|
|
|
sound = None
|
|
|
|
|
2017-11-18 20:12:16 +00:00
|
|
|
# Additional data?
|
2017-07-07 06:21:06 +00:00
|
|
|
if data is not None:
|
|
|
|
if "icon" in data:
|
|
|
|
icon = data["icon"]
|
|
|
|
if "sound" in data:
|
|
|
|
try:
|
|
|
|
sound = Sound(category="notifications",
|
|
|
|
sound_id=data["sound"])
|
|
|
|
_LOGGER.debug("Adding notification sound %s",
|
|
|
|
data["sound"])
|
|
|
|
except AssertionError:
|
|
|
|
_LOGGER.error("Sound ID %s unknown, ignoring",
|
|
|
|
data["sound"])
|
|
|
|
|
|
|
|
text_frame = SimpleFrame(icon, message)
|
2017-11-18 20:12:16 +00:00
|
|
|
_LOGGER.debug("Icon/Message/Cycles/Lifetime: %s, %s, %d, %d",
|
|
|
|
icon, message, self._cycles, self._lifetime)
|
2017-07-07 06:21:06 +00:00
|
|
|
|
|
|
|
frames = [text_frame]
|
|
|
|
|
2017-11-18 20:12:16 +00:00
|
|
|
model = Model(frames=frames, cycles=cycles, sound=sound)
|
2017-11-13 20:12:15 +00:00
|
|
|
lmn = self.hasslametricmanager.manager
|
|
|
|
try:
|
2018-03-23 17:10:52 +00:00
|
|
|
self._devices = lmn.get_devices()
|
2017-11-13 20:12:15 +00:00
|
|
|
except TokenExpiredError:
|
|
|
|
_LOGGER.debug("Token expired, fetching new token")
|
|
|
|
lmn.get_token()
|
2018-03-23 17:10:52 +00:00
|
|
|
self._devices = lmn.get_devices()
|
|
|
|
except RequestsConnectionError:
|
|
|
|
_LOGGER.warning("Problem connecting to LaMetric, "
|
|
|
|
"using cached devices instead")
|
|
|
|
for dev in self._devices:
|
2017-11-13 20:12:15 +00:00
|
|
|
if targets is None or dev["name"] in targets:
|
2018-02-18 05:13:05 +00:00
|
|
|
try:
|
|
|
|
lmn.set_device(dev)
|
|
|
|
lmn.send_notification(model, lifetime=self._lifetime)
|
|
|
|
_LOGGER.debug("Sent notification to LaMetric %s",
|
|
|
|
dev["name"])
|
|
|
|
except OSError:
|
|
|
|
_LOGGER.warning("Cannot connect to LaMetric %s",
|
|
|
|
dev["name"])
|