diff options
| author | 2020-08-12 12:11:47 -0700 | |
|---|---|---|
| committer | 2020-08-12 12:40:17 -0700 | |
| commit | 257048446a1e37c1bbdad424f8a8465f0491ca83 (patch) | |
| tree | 49cf8975dec3b07c37c3442ec959128be94a92d6 | |
| parent | Merge pull request #1097 from Numerlor/remove-api-endpoints (diff) | |
Filtering: ignore errors for duplicate offensive messages
The error happens when a filter is triggered by a message edit.
Fixes #1099
Fixes BOT-6B
| -rw-r--r-- | bot/cogs/filtering.py | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/bot/cogs/filtering.py b/bot/cogs/filtering.py index 93cc1c655..99b659bff 100644 --- a/bot/cogs/filtering.py +++ b/bot/cogs/filtering.py @@ -11,6 +11,7 @@ from discord import Colour, HTTPException, Member, Message, NotFound, TextChanne from discord.ext.commands import Cog from discord.utils import escape_markdown +from bot.api import ResponseCodeError from bot.bot import Bot from bot.cogs.moderation import ModLog from bot.constants import ( @@ -301,9 +302,16 @@ class Filtering(Cog): 'delete_date': delete_date } - await self.bot.api_client.post('bot/offensive-messages', json=data) - self.schedule_msg_delete(data) - log.trace(f"Offensive message {msg.id} will be deleted on {delete_date}") + try: + await self.bot.api_client.post('bot/offensive-messages', json=data) + except ResponseCodeError as e: + if e.status == 400 and "already exists" in e.response_json.get("id", [""])[0]: + log.debug(f"Offensive message {msg.id} already exists.") + else: + log.error(f"Offensive message {msg.id} failed to post: {e}") + else: + self.schedule_msg_delete(data) + log.trace(f"Offensive message {msg.id} will be deleted on {delete_date}") if is_private: channel_str = "via DM" |