2019-04-03 15:40:03 +00:00
|
|
|
"""Pushetta platform for notify component."""
|
2015-11-10 13:12:03 +00:00
|
|
|
import logging
|
|
|
|
|
2016-09-07 00:00:33 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
2015-11-10 13:12:03 +00:00
|
|
|
from homeassistant.const import CONF_API_KEY
|
2016-09-07 00:00:33 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
2015-11-10 13:12:03 +00:00
|
|
|
|
2019-03-28 03:36:13 +00:00
|
|
|
from homeassistant.components.notify import (
|
2019-07-31 19:25:30 +00:00
|
|
|
ATTR_TITLE,
|
|
|
|
ATTR_TITLE_DEFAULT,
|
|
|
|
PLATFORM_SCHEMA,
|
|
|
|
BaseNotificationService,
|
|
|
|
)
|
2019-03-21 05:56:46 +00:00
|
|
|
|
2015-11-10 13:12:03 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
CONF_CHANNEL_NAME = "channel_name"
|
|
|
|
CONF_SEND_TEST_MSG = "send_test_msg"
|
2016-09-07 00:00:33 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
|
|
|
{
|
|
|
|
vol.Required(CONF_API_KEY): cv.string,
|
|
|
|
vol.Required(CONF_CHANNEL_NAME): cv.string,
|
|
|
|
vol.Optional(CONF_SEND_TEST_MSG, default=False): cv.boolean,
|
|
|
|
}
|
|
|
|
)
|
2016-09-07 00:00:33 +00:00
|
|
|
|
|
|
|
|
2017-01-15 02:53:14 +00:00
|
|
|
def get_service(hass, config, discovery_info=None):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Get the Pushetta notification service."""
|
2017-05-02 16:18:47 +00:00
|
|
|
api_key = config[CONF_API_KEY]
|
|
|
|
channel_name = config[CONF_CHANNEL_NAME]
|
|
|
|
send_test_msg = config[CONF_SEND_TEST_MSG]
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
pushetta_service = PushettaNotificationService(api_key, channel_name, send_test_msg)
|
2015-11-10 13:12:03 +00:00
|
|
|
|
2016-10-02 13:36:57 +00:00
|
|
|
if pushetta_service.is_valid:
|
|
|
|
return pushetta_service
|
2015-11-10 13:12:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
class PushettaNotificationService(BaseNotificationService):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Implement the notification service for Pushetta."""
|
2015-11-10 13:12:03 +00:00
|
|
|
|
2016-10-02 13:36:57 +00:00
|
|
|
def __init__(self, api_key, channel_name, send_test_msg):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Initialize the service."""
|
2015-11-10 13:12:03 +00:00
|
|
|
from pushetta import Pushetta
|
2019-07-31 19:25:30 +00:00
|
|
|
|
2015-11-10 13:12:03 +00:00
|
|
|
self._api_key = api_key
|
|
|
|
self._channel_name = channel_name
|
2016-10-02 13:36:57 +00:00
|
|
|
self.is_valid = True
|
|
|
|
self.pushetta = Pushetta(api_key)
|
|
|
|
|
|
|
|
if send_test_msg:
|
|
|
|
self.send_message("Home Assistant started")
|
2015-11-10 13:12:03 +00:00
|
|
|
|
|
|
|
def send_message(self, message="", **kwargs):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Send a message to a user."""
|
2016-10-02 13:36:57 +00:00
|
|
|
from pushetta import exceptions
|
2019-07-31 19:25:30 +00:00
|
|
|
|
2016-09-01 13:35:46 +00:00
|
|
|
title = kwargs.get(ATTR_TITLE, ATTR_TITLE_DEFAULT)
|
2016-10-02 13:36:57 +00:00
|
|
|
|
|
|
|
try:
|
2019-07-31 19:25:30 +00:00
|
|
|
self.pushetta.pushMessage(
|
|
|
|
self._channel_name, "{} {}".format(title, message)
|
|
|
|
)
|
2016-10-02 13:36:57 +00:00
|
|
|
except exceptions.TokenValidationError:
|
|
|
|
_LOGGER.error("Please check your access token")
|
|
|
|
self.is_valid = False
|
|
|
|
except exceptions.ChannelNotFoundError:
|
|
|
|
_LOGGER.error("Channel '%s' not found", self._channel_name)
|
|
|
|
self.is_valid = False
|