rework to include checks on boot
This commit is contained in:
parent
7593ecb870
commit
94e004a828
1 changed files with 47 additions and 27 deletions
|
@ -21,23 +21,23 @@ VARIABLES:
|
||||||
api_key
|
api_key
|
||||||
*Required
|
*Required
|
||||||
To retrieve this value log into your account at https://instapush.im and go
|
To retrieve this value log into your account at https://instapush.im and go
|
||||||
to 'APPS'.
|
to 'APPS', choose an app, and check 'Basic Info'.
|
||||||
|
|
||||||
app_secret
|
app_secret
|
||||||
*Required
|
*Required
|
||||||
To get this value log into your account at https://instapush.im and go to
|
To get this value log into your account at https://instapush.im and go to
|
||||||
'APPS'. The 'Application ID' can be found under 'Basic Info'. Make sure that
|
'APPS'. The 'Application ID' can be found under 'Basic Info'.
|
||||||
you have at least one event for your app.
|
|
||||||
|
|
||||||
event
|
event
|
||||||
*Required
|
*Required
|
||||||
To retrieve this value log into your account at https://instapush.im and go
|
To retrieve a valid event log into your account at https://instapush.im and go
|
||||||
to 'APPS'.
|
to 'APPS'. If you have no events to use with Home Assistant, create one event for
|
||||||
|
your app.
|
||||||
|
|
||||||
tracker
|
tracker
|
||||||
*Required
|
*Required
|
||||||
To retrieve this value log into your account at https://instapush.im and go
|
To retrieve the tracker value log into your account at https://instapush.im and go
|
||||||
to 'APPS'.
|
to 'APPS', choose the app, and check the event entries.
|
||||||
|
|
||||||
Example usage of Instapush if you have an event 'notification' and a tracker
|
Example usage of Instapush if you have an event 'notification' and a tracker
|
||||||
'home-assistant'.
|
'home-assistant'.
|
||||||
|
@ -61,15 +61,17 @@ from homeassistant.components.notify import (
|
||||||
from homeassistant.const import CONF_API_KEY
|
from homeassistant.const import CONF_API_KEY
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
_RESOURCE = 'https://api.instapush.im/v1/post'
|
_RESOURCE = 'https://api.instapush.im/v1/'
|
||||||
|
|
||||||
|
|
||||||
def get_service(hass, config):
|
def get_service(hass, config):
|
||||||
""" Get the instapush notification service. """
|
""" Get the instapush notification service. """
|
||||||
|
|
||||||
if not validate_config(config,
|
if not validate_config(config,
|
||||||
{DOMAIN: [CONF_API_KEY, 'app_secret', \
|
{DOMAIN: [CONF_API_KEY,
|
||||||
'event', 'tracker']},
|
'app_secret',
|
||||||
|
'event',
|
||||||
|
'tracker']},
|
||||||
_LOGGER):
|
_LOGGER):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
@ -94,6 +96,25 @@ def get_service(hass, config):
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
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']:
|
||||||
|
_LOGGER.error("{}".format(response.json()['msg']))
|
||||||
|
# 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(
|
return InstapushNotificationService(
|
||||||
config[DOMAIN].get(CONF_API_KEY),
|
config[DOMAIN].get(CONF_API_KEY),
|
||||||
config[DOMAIN]['app_secret'],
|
config[DOMAIN]['app_secret'],
|
||||||
|
@ -108,34 +129,33 @@ class InstapushNotificationService(BaseNotificationService):
|
||||||
|
|
||||||
def __init__(self, api_key, app_secret, event, tracker):
|
def __init__(self, api_key, app_secret, event, tracker):
|
||||||
# pylint: disable=no-name-in-module, unused-variable
|
# pylint: disable=no-name-in-module, unused-variable
|
||||||
from requests import Request, Session
|
from requests import Session
|
||||||
|
|
||||||
self._api_key = api_key
|
self._api_key = api_key
|
||||||
self._app_secret = app_secret
|
self._app_secret = app_secret
|
||||||
self._event = event
|
self._event = event
|
||||||
self._tracker = tracker
|
self._tracker = tracker
|
||||||
self._headers = {
|
self._headers = {
|
||||||
'X-INSTAPUSH-APPID' : self._api_key,
|
'x-instapush-appid': self._api_key,
|
||||||
'X-INSTAPUSH-APPSECRET' : self._app_secret,
|
'x-instapush-appsecret': self._app_secret,
|
||||||
'Content-Type' : 'application/json'}
|
'Content-Type': 'application/json'}
|
||||||
|
|
||||||
self.instapush = Session()
|
self.instapush = Session()
|
||||||
|
|
||||||
|
|
||||||
def send_message(self, message="", **kwargs):
|
def send_message(self, message="", **kwargs):
|
||||||
""" Send a message to a user. """
|
""" Send a message to a user. """
|
||||||
|
|
||||||
title = kwargs.get(ATTR_TITLE)
|
title = kwargs.get(ATTR_TITLE)
|
||||||
|
|
||||||
data = {"event":self._event,
|
data = {"event": self._event,
|
||||||
"trackers":{self._tracker:title + " : " + message}}
|
"trackers": {self._tracker: title + " : " + message}}
|
||||||
|
|
||||||
response = self.instapush.post(
|
response = self.instapush.post(
|
||||||
_RESOURCE,
|
_RESOURCE + 'post',
|
||||||
data=json.dumps(data),
|
data=json.dumps(data),
|
||||||
headers=self._headers)
|
headers=self._headers)
|
||||||
|
|
||||||
if response.json()['error'] == 'True':
|
if response.json()['status'] == 401:
|
||||||
_LOGGER.error(
|
_LOGGER.error(
|
||||||
"Wrong details supplied. "
|
response.json()['msg'],
|
||||||
"Get them at https://instapush.im/")
|
"Please check your details at https://instapush.im/")
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue