2015-03-22 03:36:58 +00:00
|
|
|
"""
|
|
|
|
Pushover platform for notify component.
|
|
|
|
|
|
|
|
Configuration:
|
|
|
|
|
|
|
|
To use the Pushover notifier you will need to add something like the following
|
|
|
|
to your config/configuration.yaml
|
|
|
|
|
|
|
|
notify:
|
|
|
|
platform: pushover
|
2015-03-22 04:13:57 +00:00
|
|
|
api_key: ABCDEFGHJKLMNOPQRSTUVXYZ
|
2015-03-22 03:36:58 +00:00
|
|
|
user_key: ABCDEFGHJKLMNOPQRSTUVXYZ
|
|
|
|
|
|
|
|
VARIABLES:
|
|
|
|
|
2015-03-22 04:13:57 +00:00
|
|
|
api_key
|
|
|
|
*Required
|
|
|
|
This parameter is optional but should be configured, in order to get an API
|
|
|
|
key you should go to pushover.com and register a new application.
|
|
|
|
|
|
|
|
This is a quote from the pushover website regarding free/open source apps:
|
|
|
|
"If you are creating a client-side library, application, or open source project
|
|
|
|
that will be redistributed and installed by end-users, you may want to require
|
|
|
|
each of your users to register their own application rather than including your
|
|
|
|
own API token with the software."
|
|
|
|
|
|
|
|
When setting up the application I recommend using the icon located here:
|
|
|
|
https://home-assistant.io/images/favicon-192x192.png
|
|
|
|
|
2015-03-22 03:36:58 +00:00
|
|
|
user_key
|
|
|
|
*Required
|
|
|
|
To retrieve this value log into your account at http://pushover.com
|
|
|
|
|
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from homeassistant.helpers import validate_config
|
|
|
|
from homeassistant.components.notify import (
|
|
|
|
DOMAIN, ATTR_TITLE, BaseNotificationService)
|
2015-03-22 04:13:57 +00:00
|
|
|
from homeassistant.const import CONF_API_KEY
|
2015-03-22 03:36:58 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2015-03-22 04:32:47 +00:00
|
|
|
# pylint: disable=unused-variable
|
2015-03-22 03:36:58 +00:00
|
|
|
def get_service(hass, config):
|
|
|
|
""" Get the pushover notification service. """
|
|
|
|
|
|
|
|
if not validate_config(config,
|
2015-03-22 04:13:57 +00:00
|
|
|
{DOMAIN: ['user_key', CONF_API_KEY]},
|
2015-03-22 03:36:58 +00:00
|
|
|
_LOGGER):
|
|
|
|
return None
|
|
|
|
|
|
|
|
try:
|
2015-03-22 04:32:47 +00:00
|
|
|
# pylint: disable=no-name-in-module, unused-variable
|
|
|
|
from pushover import InitError
|
2015-03-22 03:36:58 +00:00
|
|
|
|
|
|
|
except ImportError:
|
|
|
|
_LOGGER.exception(
|
|
|
|
"Unable to import pushover. "
|
|
|
|
"Did you maybe not install the 'python-pushover.py' package?")
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
try:
|
2015-03-22 04:13:57 +00:00
|
|
|
api_token = config[DOMAIN].get(CONF_API_KEY)
|
|
|
|
return PushoverNotificationService(
|
2015-03-22 04:32:47 +00:00
|
|
|
config[DOMAIN]['user_key'],
|
|
|
|
api_token)
|
2015-03-22 03:36:58 +00:00
|
|
|
|
2015-03-22 04:13:57 +00:00
|
|
|
except InitError:
|
2015-03-22 03:36:58 +00:00
|
|
|
_LOGGER.error(
|
|
|
|
"Wrong API key supplied. "
|
|
|
|
"Get it at https://www.pushover.com")
|
|
|
|
|
|
|
|
|
|
|
|
# pylint: disable=too-few-public-methods
|
|
|
|
class PushoverNotificationService(BaseNotificationService):
|
|
|
|
""" Implements notification service for Pushover. """
|
|
|
|
|
2015-03-22 04:13:57 +00:00
|
|
|
def __init__(self, user_key, api_token):
|
2015-03-22 04:32:47 +00:00
|
|
|
# pylint: disable=no-name-in-module, unused-variable
|
|
|
|
from pushover import Client
|
2015-03-22 04:13:57 +00:00
|
|
|
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)
|
2015-03-22 03:36:58 +00:00
|
|
|
|
|
|
|
def send_message(self, message="", **kwargs):
|
|
|
|
""" Send a message to a user. """
|
|
|
|
|
2015-03-22 04:32:47 +00:00
|
|
|
# pylint: disable=no-name-in-module
|
|
|
|
from pushover import RequestError
|
2015-03-22 03:36:58 +00:00
|
|
|
title = kwargs.get(ATTR_TITLE)
|
2015-03-22 04:13:57 +00:00
|
|
|
try:
|
|
|
|
self.pushover.send_message(message, title=title)
|
|
|
|
except RequestError:
|
|
|
|
_LOGGER.exception("Could not send pushover notification")
|