core/homeassistant/components/discord/notify.py

92 lines
3.0 KiB
Python
Raw Normal View History

"""Discord platform for notify component."""
import logging
import voluptuous as vol
from homeassistant.const import CONF_TOKEN
import homeassistant.helpers.config_validation as cv
from homeassistant.components.notify import (ATTR_DATA, ATTR_TARGET,
PLATFORM_SCHEMA,
BaseNotificationService)
_LOGGER = logging.getLogger(__name__)
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_TOKEN): cv.string
})
ATTR_IMAGES = 'images'
def get_service(hass, config, discovery_info=None):
"""Get the Discord notification service."""
token = config.get(CONF_TOKEN)
return DiscordNotificationService(hass, token)
class DiscordNotificationService(BaseNotificationService):
"""Implement the notification service for Discord."""
def __init__(self, hass, token):
"""Initialize the service."""
self.token = token
self.hass = hass
async def async_send_message(self, message, **kwargs):
"""Login to Discord, send message to channel(s) and log out."""
import discord
discord.VoiceClient.warn_nacl = False
discord_bot = discord.Client(loop=self.hass.loop)
2019-04-30 20:12:39 +00:00
images = None
2017-03-04 00:03:10 +00:00
if ATTR_TARGET not in kwargs:
_LOGGER.error("No target specified")
return None
2019-04-30 20:12:39 +00:00
if ATTR_DATA in kwargs:
data = kwargs.get(ATTR_DATA)
if ATTR_IMAGES in data:
import os.path
images = list()
for image in data.get(ATTR_IMAGES):
if os.path.isfile(image):
images.append(image)
else:
_LOGGER.warning("Image not found: %s", image)
# pylint: disable=unused-variable
2017-03-03 22:15:03 +00:00
@discord_bot.event
async def on_ready():
2017-03-04 00:43:59 +00:00
"""Send the messages when the bot is ready."""
try:
for channelid in kwargs[ATTR_TARGET]:
2019-04-30 20:12:39 +00:00
channelid = int(channelid)
channel = discord_bot.get_channel(channelid)
if channel is None:
_LOGGER.warning(
"Channel not found for id: %s",
channelid)
continue
# Must create new instances of File for each channel.
files = None
if images:
2019-04-30 20:12:39 +00:00
files = list()
for image in images:
files.append(discord.File(image))
await channel.send(message, files=files)
except (discord.errors.HTTPException,
discord.errors.NotFound) as error:
_LOGGER.warning("Communication error: %s", error)
await discord_bot.logout()
await discord_bot.close()
2019-04-30 20:12:39 +00:00
# Using reconnect=False prevents multiple ready events to be fired.
await discord_bot.start(self.token, reconnect=False)