2016-06-25 04:43:44 +00:00
|
|
|
"""
|
|
|
|
A component which is collecting configuration errors.
|
|
|
|
|
|
|
|
For more details about this component, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/persistent_notification/
|
|
|
|
"""
|
2016-10-24 06:48:01 +00:00
|
|
|
import asyncio
|
2016-07-04 01:33:23 +00:00
|
|
|
import os
|
2016-06-25 23:40:33 +00:00
|
|
|
import logging
|
2016-06-25 04:43:44 +00:00
|
|
|
|
2016-06-25 23:40:33 +00:00
|
|
|
import voluptuous as vol
|
2016-06-25 04:43:44 +00:00
|
|
|
|
2016-10-27 07:16:23 +00:00
|
|
|
from homeassistant.core import callback
|
2016-06-25 23:40:33 +00:00
|
|
|
from homeassistant.exceptions import TemplateError
|
2016-09-28 04:29:55 +00:00
|
|
|
from homeassistant.helpers import config_validation as cv
|
2016-10-27 07:16:23 +00:00
|
|
|
from homeassistant.helpers.entity import async_generate_entity_id
|
2016-06-25 23:40:33 +00:00
|
|
|
from homeassistant.util import slugify
|
2016-07-04 01:33:23 +00:00
|
|
|
from homeassistant.config import load_yaml_config_file
|
2016-06-25 04:43:44 +00:00
|
|
|
|
2017-04-30 05:04:49 +00:00
|
|
|
ATTR_MESSAGE = 'message'
|
|
|
|
ATTR_NOTIFICATION_ID = 'notification_id'
|
|
|
|
ATTR_TITLE = 'title'
|
|
|
|
|
2016-06-25 23:40:33 +00:00
|
|
|
DOMAIN = 'persistent_notification'
|
2017-04-30 05:04:49 +00:00
|
|
|
|
2016-06-25 23:40:33 +00:00
|
|
|
ENTITY_ID_FORMAT = DOMAIN + '.{}'
|
|
|
|
|
|
|
|
SERVICE_CREATE = 'create'
|
|
|
|
|
|
|
|
SCHEMA_SERVICE_CREATE = vol.Schema({
|
|
|
|
vol.Required(ATTR_MESSAGE): cv.template,
|
|
|
|
vol.Optional(ATTR_TITLE): cv.template,
|
|
|
|
vol.Optional(ATTR_NOTIFICATION_ID): cv.string,
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
DEFAULT_OBJECT_ID = 'notification'
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
def create(hass, message, title=None, notification_id=None):
|
2016-10-24 06:48:01 +00:00
|
|
|
"""Generate a notification."""
|
2017-02-23 20:57:25 +00:00
|
|
|
hass.add_job(async_create, hass, message, title, notification_id)
|
2016-10-24 06:48:01 +00:00
|
|
|
|
|
|
|
|
2016-10-27 07:16:23 +00:00
|
|
|
@callback
|
2016-10-24 06:48:01 +00:00
|
|
|
def async_create(hass, message, title=None, notification_id=None):
|
2016-07-01 19:39:30 +00:00
|
|
|
"""Generate a notification."""
|
2016-06-25 23:40:33 +00:00
|
|
|
data = {
|
|
|
|
key: value for key, value in [
|
|
|
|
(ATTR_TITLE, title),
|
|
|
|
(ATTR_MESSAGE, message),
|
|
|
|
(ATTR_NOTIFICATION_ID, notification_id),
|
|
|
|
] if value is not None
|
|
|
|
}
|
|
|
|
|
2016-11-08 06:31:40 +00:00
|
|
|
hass.async_add_job(hass.services.async_call(DOMAIN, SERVICE_CREATE, data))
|
2016-06-25 04:43:44 +00:00
|
|
|
|
|
|
|
|
2016-10-27 07:16:23 +00:00
|
|
|
@asyncio.coroutine
|
|
|
|
def async_setup(hass, config):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Set up the persistent notification component."""
|
2016-10-27 07:16:23 +00:00
|
|
|
@callback
|
2016-06-25 23:40:33 +00:00
|
|
|
def create_service(call):
|
|
|
|
"""Handle a create notification service call."""
|
|
|
|
title = call.data.get(ATTR_TITLE)
|
|
|
|
message = call.data.get(ATTR_MESSAGE)
|
|
|
|
notification_id = call.data.get(ATTR_NOTIFICATION_ID)
|
|
|
|
|
|
|
|
if notification_id is not None:
|
|
|
|
entity_id = ENTITY_ID_FORMAT.format(slugify(notification_id))
|
|
|
|
else:
|
2016-10-27 07:16:23 +00:00
|
|
|
entity_id = async_generate_entity_id(
|
|
|
|
ENTITY_ID_FORMAT, DEFAULT_OBJECT_ID, hass=hass)
|
2016-06-25 23:40:33 +00:00
|
|
|
attr = {}
|
|
|
|
if title is not None:
|
|
|
|
try:
|
2016-09-28 04:29:55 +00:00
|
|
|
title.hass = hass
|
2016-10-27 07:16:23 +00:00
|
|
|
title = title.async_render()
|
2016-06-25 23:40:33 +00:00
|
|
|
except TemplateError as ex:
|
|
|
|
_LOGGER.error('Error rendering title %s: %s', title, ex)
|
2016-09-28 04:29:55 +00:00
|
|
|
title = title.template
|
2016-06-25 23:40:33 +00:00
|
|
|
|
|
|
|
attr[ATTR_TITLE] = title
|
|
|
|
|
|
|
|
try:
|
2016-09-28 04:29:55 +00:00
|
|
|
message.hass = hass
|
2016-10-27 07:16:23 +00:00
|
|
|
message = message.async_render()
|
2016-06-25 23:40:33 +00:00
|
|
|
except TemplateError as ex:
|
|
|
|
_LOGGER.error('Error rendering message %s: %s', message, ex)
|
2016-09-28 04:29:55 +00:00
|
|
|
message = message.template
|
2016-06-25 23:40:33 +00:00
|
|
|
|
2016-10-27 07:16:23 +00:00
|
|
|
hass.states.async_set(entity_id, message, attr)
|
2016-06-25 23:40:33 +00:00
|
|
|
|
2016-10-27 07:16:23 +00:00
|
|
|
descriptions = yield from hass.loop.run_in_executor(
|
|
|
|
None, load_yaml_config_file, os.path.join(
|
|
|
|
os.path.dirname(__file__), 'services.yaml')
|
|
|
|
)
|
|
|
|
hass.services.async_register(DOMAIN, SERVICE_CREATE, create_service,
|
|
|
|
descriptions[DOMAIN][SERVICE_CREATE],
|
|
|
|
SCHEMA_SERVICE_CREATE)
|
2016-06-25 23:40:33 +00:00
|
|
|
|
2016-06-25 04:43:44 +00:00
|
|
|
return True
|