core/homeassistant/components/pushover/notify.py

71 lines
2.0 KiB
Python
Raw Normal View History

"""Pushover platform for notify component."""
import logging
2016-08-27 00:43:59 +00:00
import voluptuous as vol
from homeassistant.const import CONF_API_KEY
2016-08-27 00:43:59 +00:00
import homeassistant.helpers.config_validation as cv
from homeassistant.components.notify import (
ATTR_DATA, ATTR_TARGET, ATTR_TITLE, ATTR_TITLE_DEFAULT, PLATFORM_SCHEMA,
BaseNotificationService)
_LOGGER = logging.getLogger(__name__)
CONF_USER_KEY = 'user_key'
2019-02-14 20:06:25 +00:00
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_USER_KEY): cv.string,
2016-08-27 00:43:59 +00:00
vol.Required(CONF_API_KEY): cv.string,
})
def get_service(hass, config, discovery_info=None):
2016-03-08 10:46:32 +00:00
"""Get the Pushover notification service."""
2015-11-09 06:15:34 +00:00
from pushover import InitError
try:
return PushoverNotificationService(
config[CONF_USER_KEY], config[CONF_API_KEY])
except InitError:
_LOGGER.error("Wrong API key supplied")
2015-11-09 06:15:34 +00:00
return None
class PushoverNotificationService(BaseNotificationService):
2016-03-08 10:46:32 +00:00
"""Implement the notification service for Pushover."""
def __init__(self, user_key, api_token):
2016-03-08 10:46:32 +00:00
"""Initialize the service."""
2015-03-22 04:32:47 +00:00
from pushover import Client
self._user_key = user_key
self._api_token = api_token
2015-03-22 04:32:47 +00:00
self.pushover = Client(
self._user_key, api_token=self._api_token)
2016-08-27 00:43:59 +00:00
def send_message(self, message='', **kwargs):
2016-03-08 10:46:32 +00:00
"""Send a message to a user."""
2015-03-22 04:32:47 +00:00
from pushover import RequestError
2015-11-09 06:15:34 +00:00
# Make a copy and use empty dict if necessary
data = dict(kwargs.get(ATTR_DATA) or {})
data['title'] = kwargs.get(ATTR_TITLE, ATTR_TITLE_DEFAULT)
targets = kwargs.get(ATTR_TARGET)
if not isinstance(targets, list):
targets = [targets]
for target in targets:
if target is not None:
data['device'] = target
try:
self.pushover.send_message(message, **data)
except ValueError as val_err:
_LOGGER.error(str(val_err))
except RequestError:
_LOGGER.exception("Could not send pushover notification")