diff options
Diffstat (limited to 'bot/exts/moderation/modlog.py')
| -rw-r--r-- | bot/exts/moderation/modlog.py | 47 | 
1 files changed, 30 insertions, 17 deletions
| diff --git a/bot/exts/moderation/modlog.py b/bot/exts/moderation/modlog.py index 80f68e442..67991730e 100644 --- a/bot/exts/moderation/modlog.py +++ b/bot/exts/moderation/modlog.py @@ -6,12 +6,14 @@ from datetime import datetime, timezone  from itertools import zip_longest  import discord +from botcore.site_api import ResponseCodeError  from dateutil.relativedelta import relativedelta  from deepdiff import DeepDiff  from discord import Colour, Message, Thread  from discord.abc import GuildChannel  from discord.ext.commands import Cog, Context  from discord.utils import escape_markdown, format_dt, snowflake_time +from sentry_sdk import add_breadcrumb  from bot.bot import Bot  from bot.constants import Categories, Channels, Colours, Emojis, Event, Guild as GuildConstant, Icons, Roles, URLs @@ -53,24 +55,35 @@ class ModLog(Cog, name="ModLog"):          if attachments is None:              attachments = [] -        response = await self.bot.api_client.post( -            'bot/deleted-messages', -            json={ -                'actor': actor_id, -                'creation': datetime.now(timezone.utc).isoformat(), -                'deletedmessage_set': [ -                    { -                        'id': message.id, -                        'author': message.author.id, -                        'channel_id': message.channel.id, -                        'content': message.content.replace("\0", ""),  # Null chars cause 400. -                        'embeds': [embed.to_dict() for embed in message.embeds], -                        'attachments': attachment, -                    } -                    for message, attachment in zip_longest(messages, attachments, fillvalue=[]) -                ] +        deletedmessage_set = [ +            { +                "id": message.id, +                "author": message.author.id, +                "channel_id": message.channel.id, +                "content": message.content.replace("\0", ""),  # Null chars cause 400. +                "embeds": [embed.to_dict() for embed in message.embeds], +                "attachments": attachment,              } -        ) +            for message, attachment in zip_longest(messages, attachments, fillvalue=[]) +        ] + +        try: +            response = await self.bot.api_client.post( +                "bot/deleted-messages", +                json={ +                    "actor": actor_id, +                    "creation": datetime.now(timezone.utc).isoformat(), +                    "deletedmessage_set": deletedmessage_set, +                } +            ) +        except ResponseCodeError as e: +            add_breadcrumb( +                category="api_error", +                message=str(e), +                level="error", +                data=deletedmessage_set, +            ) +            raise          return f"{URLs.site_logs_view}/{response['id']}" | 
