no longer use pynma and check if keys are ok

This commit is contained in:
Fabian Affolter 2015-04-27 14:52:22 +02:00
parent 07f62fda32
commit 4a5c32e375

View file

@ -17,11 +17,14 @@ VARIABLES:
api_key api_key
*Required *Required
Enter the API for NMA. Go to https://www.notifymyandroid.com and create a Enter the API key for NMA. Go to https://www.notifymyandroid.com and create a
new API to use with Home Assistant. new API key to use with Home Assistant.
Details for the API : https://www.notifymyandroid.com/api.jsp
""" """
import logging import logging
import xml.etree.ElementTree as ET
from homeassistant.helpers import validate_config from homeassistant.helpers import validate_config
from homeassistant.components.notify import ( from homeassistant.components.notify import (
@ -29,6 +32,7 @@ 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://www.notifymyandroid.com/publicapi/'
def get_service(hass, config): def get_service(hass, config):
@ -41,28 +45,52 @@ def get_service(hass, config):
try: try:
# pylint: disable=unused-variable # pylint: disable=unused-variable
from homeassistant.external.pynma.pynma import PyNMA from requests import Request, Session
except ImportError: except ImportError:
_LOGGER.exception( _LOGGER.exception(
"Unable to import pyNMA. " "Unable to import requests. "
"Did you maybe not install the 'PyNMA' package?") "Did you maybe not install the 'Requests' package?")
return None return None
nma = Session()
response = nma.get(_RESOURCE + 'verify', params={"apikey" : config[DOMAIN][CONF_API_KEY]})
tree = ET.fromstring(response.content)
if tree[0].tag == 'error':
_LOGGER.error(
"Wrong API key supplied. "
"Error: {}".format(tree[0].text))
else:
return NmaNotificationService(config[DOMAIN][CONF_API_KEY])
# pylint: disable=too-few-public-methods # pylint: disable=too-few-public-methods
class NmaNotificationService(BaseNotificationService): class NmaNotificationService(BaseNotificationService):
""" Implements notification service for NMA. """ """ Implements notification service for NMA. """
def __init__(self, api_key): def __init__(self, api_key):
from homeassistant.external.pynma.pynma import PyNMA # pylint: disable=no-name-in-module, unused-variable
from requests import Request, Session
self.nma = PyNMA(api_key) self._api_key = api_key
self._data = {"apikey" : self._api_key}
self.nma = 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)
self.nma.push('home-assistant', title, message) self._data['application'] = 'home-assistant'
self._data['event'] = title
self._data['description'] = message
self._data['priority'] = 0
response = self.nma.get(_RESOURCE + 'notify', params=self._data)
tree = ET.fromstring(response.content)
if tree[0].tag == 'error':
_LOGGER.exception(
"Unable to perform request. "
"Error: {}".format(tree[0].text))