2015-04-25 22:53:36 +00:00
|
|
|
"""
|
|
|
|
homeassistant.components.notify.instapush
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Instapush notification service.
|
|
|
|
|
2015-10-13 21:08:56 +00:00
|
|
|
For more details about this platform, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/notify.instapush.html
|
2015-04-25 22:53:36 +00:00
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
import json
|
|
|
|
|
|
|
|
from homeassistant.helpers import validate_config
|
|
|
|
from homeassistant.components.notify import (
|
|
|
|
DOMAIN, ATTR_TITLE, BaseNotificationService)
|
|
|
|
from homeassistant.const import CONF_API_KEY
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
2015-04-27 17:34:34 +00:00
|
|
|
_RESOURCE = 'https://api.instapush.im/v1/'
|
2015-04-25 22:53:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
def get_service(hass, config):
|
|
|
|
""" Get the instapush notification service. """
|
|
|
|
|
|
|
|
if not validate_config(config,
|
2015-04-27 17:34:34 +00:00
|
|
|
{DOMAIN: [CONF_API_KEY,
|
|
|
|
'app_secret',
|
|
|
|
'event',
|
|
|
|
'tracker']},
|
2015-04-25 22:53:36 +00:00
|
|
|
_LOGGER):
|
|
|
|
return None
|
|
|
|
|
|
|
|
try:
|
|
|
|
import requests
|
|
|
|
|
|
|
|
except ImportError:
|
|
|
|
_LOGGER.exception(
|
|
|
|
"Unable to import requests. "
|
|
|
|
"Did you maybe not install the 'Requests' package?")
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
# pylint: disable=unused-variable
|
|
|
|
try:
|
|
|
|
response = requests.get(_RESOURCE)
|
|
|
|
|
|
|
|
except requests.ConnectionError:
|
|
|
|
_LOGGER.error(
|
|
|
|
"Connection error "
|
|
|
|
"Please check if https://instapush.im is available.")
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
2015-04-27 17:34:34 +00:00
|
|
|
instapush = requests.Session()
|
|
|
|
headers = {'x-instapush-appid': config[DOMAIN][CONF_API_KEY],
|
|
|
|
'x-instapush-appsecret': config[DOMAIN]['app_secret']}
|
|
|
|
response = instapush.get(_RESOURCE + 'events/list',
|
|
|
|
headers=headers)
|
|
|
|
|
|
|
|
try:
|
|
|
|
if response.json()['error']:
|
2015-04-28 07:43:53 +00:00
|
|
|
_LOGGER.error(response.json()['msg'])
|
2015-04-27 17:34:34 +00:00
|
|
|
# pylint: disable=bare-except
|
|
|
|
except:
|
|
|
|
try:
|
|
|
|
next(events for events in response.json()
|
|
|
|
if events['title'] == config[DOMAIN]['event'])
|
|
|
|
except StopIteration:
|
|
|
|
_LOGGER.error(
|
|
|
|
"No event match your given value. "
|
|
|
|
"Please create an event at https://instapush.im")
|
|
|
|
else:
|
|
|
|
return InstapushNotificationService(
|
|
|
|
config[DOMAIN].get(CONF_API_KEY),
|
|
|
|
config[DOMAIN]['app_secret'],
|
|
|
|
config[DOMAIN]['event'],
|
|
|
|
config[DOMAIN]['tracker']
|
|
|
|
)
|
2015-04-25 22:53:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
# pylint: disable=too-few-public-methods
|
|
|
|
class InstapushNotificationService(BaseNotificationService):
|
|
|
|
""" Implements notification service for Instapush. """
|
|
|
|
|
|
|
|
def __init__(self, api_key, app_secret, event, tracker):
|
|
|
|
# pylint: disable=no-name-in-module, unused-variable
|
2015-04-27 17:34:34 +00:00
|
|
|
from requests import Session
|
2015-04-25 22:53:36 +00:00
|
|
|
|
|
|
|
self._api_key = api_key
|
|
|
|
self._app_secret = app_secret
|
|
|
|
self._event = event
|
|
|
|
self._tracker = tracker
|
|
|
|
self._headers = {
|
2015-04-27 17:34:34 +00:00
|
|
|
'x-instapush-appid': self._api_key,
|
|
|
|
'x-instapush-appsecret': self._app_secret,
|
|
|
|
'Content-Type': 'application/json'}
|
2015-04-25 22:53:36 +00:00
|
|
|
|
|
|
|
self.instapush = Session()
|
|
|
|
|
|
|
|
def send_message(self, message="", **kwargs):
|
|
|
|
""" Send a message to a user. """
|
|
|
|
|
|
|
|
title = kwargs.get(ATTR_TITLE)
|
|
|
|
|
2015-04-27 17:34:34 +00:00
|
|
|
data = {"event": self._event,
|
|
|
|
"trackers": {self._tracker: title + " : " + message}}
|
2015-04-25 22:53:36 +00:00
|
|
|
|
|
|
|
response = self.instapush.post(
|
2015-04-27 17:34:34 +00:00
|
|
|
_RESOURCE + 'post',
|
2015-04-25 22:53:36 +00:00
|
|
|
data=json.dumps(data),
|
|
|
|
headers=self._headers)
|
|
|
|
|
2015-04-27 17:34:34 +00:00
|
|
|
if response.json()['status'] == 401:
|
2015-04-25 22:53:36 +00:00
|
|
|
_LOGGER.error(
|
2015-04-27 17:34:34 +00:00
|
|
|
response.json()['msg'],
|
|
|
|
"Please check your details at https://instapush.im/")
|