2019-04-03 15:40:03 +00:00
|
|
|
"""Prowl notification service."""
|
2018-01-15 22:24:12 +00:00
|
|
|
import asyncio
|
2019-03-21 05:56:46 +00:00
|
|
|
import logging
|
2018-01-15 22:24:12 +00:00
|
|
|
|
|
|
|
import async_timeout
|
|
|
|
import voluptuous as vol
|
|
|
|
|
2019-03-28 03:36:13 +00:00
|
|
|
from homeassistant.components.notify import (
|
2019-07-31 19:25:30 +00:00
|
|
|
ATTR_DATA,
|
|
|
|
ATTR_TITLE,
|
|
|
|
ATTR_TITLE_DEFAULT,
|
|
|
|
PLATFORM_SCHEMA,
|
|
|
|
BaseNotificationService,
|
|
|
|
)
|
2019-12-09 13:29:39 +00:00
|
|
|
from homeassistant.const import CONF_API_KEY
|
|
|
|
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
|
|
|
import homeassistant.helpers.config_validation as cv
|
2018-01-15 22:24:12 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
2019-07-31 19:25:30 +00:00
|
|
|
_RESOURCE = "https://api.prowlapp.com/publicapi/"
|
2018-01-15 22:24:12 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({vol.Required(CONF_API_KEY): cv.string})
|
2018-01-15 22:24:12 +00:00
|
|
|
|
|
|
|
|
2018-10-01 06:58:21 +00:00
|
|
|
async def async_get_service(hass, config, discovery_info=None):
|
2018-01-15 22:24:12 +00:00
|
|
|
"""Get the Prowl notification service."""
|
|
|
|
return ProwlNotificationService(hass, config[CONF_API_KEY])
|
|
|
|
|
|
|
|
|
|
|
|
class ProwlNotificationService(BaseNotificationService):
|
|
|
|
"""Implement the notification service for Prowl."""
|
|
|
|
|
|
|
|
def __init__(self, hass, api_key):
|
|
|
|
"""Initialize the service."""
|
|
|
|
self._hass = hass
|
|
|
|
self._api_key = api_key
|
|
|
|
|
2018-10-01 06:58:21 +00:00
|
|
|
async def async_send_message(self, message, **kwargs):
|
2018-01-15 22:24:12 +00:00
|
|
|
"""Send the message to the user."""
|
|
|
|
response = None
|
|
|
|
session = None
|
2019-07-31 19:25:30 +00:00
|
|
|
url = "{}{}".format(_RESOURCE, "add")
|
2018-01-15 22:24:12 +00:00
|
|
|
data = kwargs.get(ATTR_DATA)
|
|
|
|
payload = {
|
2019-07-31 19:25:30 +00:00
|
|
|
"apikey": self._api_key,
|
|
|
|
"application": "Home-Assistant",
|
|
|
|
"event": kwargs.get(ATTR_TITLE, ATTR_TITLE_DEFAULT),
|
|
|
|
"description": message,
|
|
|
|
"priority": data["priority"] if data and "priority" in data else 0,
|
2018-01-15 22:24:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
_LOGGER.debug("Attempting call Prowl service at %s", url)
|
|
|
|
session = async_get_clientsession(self._hass)
|
|
|
|
|
|
|
|
try:
|
2019-05-23 04:09:59 +00:00
|
|
|
with async_timeout.timeout(10):
|
2018-10-01 06:58:21 +00:00
|
|
|
response = await session.post(url, data=payload)
|
|
|
|
result = await response.text()
|
2018-01-15 22:24:12 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
if response.status != 200 or "error" in result:
|
|
|
|
_LOGGER.error(
|
2020-01-02 19:17:10 +00:00
|
|
|
"Prowl service returned http status %d, response %s",
|
2019-07-31 19:25:30 +00:00
|
|
|
response.status,
|
|
|
|
result,
|
|
|
|
)
|
2018-01-15 22:24:12 +00:00
|
|
|
except asyncio.TimeoutError:
|
|
|
|
_LOGGER.error("Timeout accessing Prowl at %s", url)
|