From 91927195b64d4775758407c7e87098a634c39397 Mon Sep 17 00:00:00 2001 From: TrustyJAID Date: Wed, 22 May 2024 00:27:04 -0600 Subject: [PATCH] [NotSoBot] Catch Tenor API errors --- notsobot/converter.py | 26 ++++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/notsobot/converter.py b/notsobot/converter.py index 3098a6fec4..a757085d56 100644 --- a/notsobot/converter.py +++ b/notsobot/converter.py @@ -9,6 +9,7 @@ import unidecode from discord.ext.commands.converter import Converter from discord.ext.commands.errors import BadArgument +from red_commons.logging import getLogger from redbot.core import commands IMAGE_LINKS: Pattern = re.compile( @@ -23,6 +24,8 @@ VALID_CONTENT_TYPES = ("image/png", "image/jpeg", "image/jpg", "image/gif") +log = getLogger("red.trusty-cogs.NotSoBot") + class TenorError(Exception): pass @@ -95,10 +98,14 @@ async def convert( api = ctx.cog.tenor if api: tenor_matches = [m.group("image_id") for m in tenor_matches] - posts = await api.posts(tenor_matches) - for post in posts: - if "gif" in post.media_formats: - urls.append(post.media_formats["gif"].url) + try: + posts = await api.posts(tenor_matches) + for post in posts: + if "gif" in post.media_formats: + urls.append(post.media_formats["gif"].url) + except TenorError as e: + log.error("Error getting tenor image information. %s", e) + if matches: for match in matches: urls.append(match.group(1)) @@ -167,10 +174,13 @@ async def search_for_images( if tenor: api = ctx.cog.tenor if api: - posts = await api.posts([tenor.group("image_id")]) - for post in posts: - if "gif" in post.media_formats: - urls.append(post.media_formats["gif"].url) + try: + posts = await api.posts([tenor.group("image_id")]) + for post in posts: + if "gif" in post.media_formats: + urls.append(post.media_formats["gif"].url) + except TenorError as e: + log.error("Error getting tenor image information. %s", e) if not urls: raise BadArgument("No Images found in recent history.") return urls