50 lines
1.3 KiB
Python
50 lines
1.3 KiB
Python
"""Support for Netgear LTE notifications."""
|
|
import logging
|
|
|
|
import attr
|
|
import eternalegypt
|
|
|
|
from homeassistant.components.notify import ATTR_TARGET, BaseNotificationService
|
|
|
|
from . import CONF_NOTIFY, CONF_RECIPIENT, DATA_KEY
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
async def async_get_service(hass, config, discovery_info=None):
|
|
"""Get the notification service."""
|
|
if discovery_info is None:
|
|
return
|
|
|
|
return NetgearNotifyService(hass, discovery_info)
|
|
|
|
|
|
@attr.s
|
|
class NetgearNotifyService(BaseNotificationService):
|
|
"""Implementation of a notification service."""
|
|
|
|
hass = attr.ib()
|
|
config = attr.ib()
|
|
|
|
async def async_send_message(self, message="", **kwargs):
|
|
"""Send a message to a user."""
|
|
|
|
modem_data = self.hass.data[DATA_KEY].get_modem_data(self.config)
|
|
if not modem_data:
|
|
_LOGGER.error("Modem not ready")
|
|
return
|
|
|
|
targets = kwargs.get(ATTR_TARGET, self.config[CONF_NOTIFY][CONF_RECIPIENT])
|
|
if not targets:
|
|
_LOGGER.warning("No recipients")
|
|
return
|
|
|
|
if not message:
|
|
return
|
|
|
|
for target in targets:
|
|
try:
|
|
await modem_data.modem.sms(target, message)
|
|
except eternalegypt.Error:
|
|
_LOGGER.error("Unable to send to %s", target)
|