"""LlamaLab Automate notification service.""" import logging import requests import voluptuous as vol from homeassistant.const import CONF_API_KEY, CONF_DEVICE from homeassistant.helpers import config_validation as cv from homeassistant.components.notify import PLATFORM_SCHEMA, BaseNotificationService _LOGGER = logging.getLogger(__name__) _RESOURCE = "https://llamalab.com/automate/cloud/message" CONF_TO = "to" PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend( { vol.Required(CONF_API_KEY): cv.string, vol.Required(CONF_TO): cv.string, vol.Optional(CONF_DEVICE): cv.string, } ) def get_service(hass, config, discovery_info=None): """Get the LlamaLab Automate notification service.""" secret = config.get(CONF_API_KEY) recipient = config.get(CONF_TO) device = config.get(CONF_DEVICE) return AutomateNotificationService(secret, recipient, device) class AutomateNotificationService(BaseNotificationService): """Implement the notification service for LlamaLab Automate.""" def __init__(self, secret, recipient, device=None): """Initialize the service.""" self._secret = secret self._recipient = recipient self._device = device def send_message(self, message="", **kwargs): """Send a message to a user.""" _LOGGER.debug("Sending to: %s, %s", self._recipient, str(self._device)) data = { "secret": self._secret, "to": self._recipient, "device": self._device, "payload": message, } response = requests.post(_RESOURCE, json=data) if response.status_code != 200: _LOGGER.error("Error sending message: %s", response)