diff options
| author | 2020-02-23 06:15:27 -0700 | |
|---|---|---|
| committer | 2020-02-23 06:15:27 -0700 | |
| commit | 43cda485fe325b3e8802e77f9b86e3356b4c5f1b (patch) | |
| tree | bd73b63f3b2a2a5ae69549eefc1bd764aaa90b79 | |
| parent | Don't set project log level so it uses root level. (diff) | |
| parent | Don't log exception traceback on Forbidden for welcomes. (diff) | |
Merge pull request #772 from python-discord/dm_failure_fix
Don't log exception traceback on Forbidden for welcomes.
| -rw-r--r-- | bot/cogs/verification.py | 21 | 
1 files changed, 9 insertions, 12 deletions
| diff --git a/bot/cogs/verification.py b/bot/cogs/verification.py index 988e0d49a..f13ccd728 100644 --- a/bot/cogs/verification.py +++ b/bot/cogs/verification.py @@ -1,7 +1,8 @@  import logging +from contextlib import suppress  from datetime import datetime -from discord import Colour, Message, NotFound, Object +from discord import Colour, Forbidden, Message, NotFound, Object  from discord.ext import tasks  from discord.ext.commands import Cog, Context, command @@ -127,17 +128,13 @@ class Verification(Cog):          await ctx.author.add_roles(Object(Roles.verified), reason="Accepted the rules")          try:              await ctx.author.send(WELCOME_MESSAGE) -        except Exception: -            # Catch the exception, in case they have DMs off or something -            log.exception(f"Unable to send welcome message to user {ctx.author}.") - -        log.trace(f"Deleting the message posted by {ctx.author}.") - -        try: -            self.mod_log.ignore(Event.message_delete, ctx.message.id) -            await ctx.message.delete() -        except NotFound: -            log.trace("No message found, it must have been deleted by another bot.") +        except Forbidden: +            log.info(f"Sending welcome message failed for {ctx.author}.") +        finally: +            log.trace(f"Deleting accept message by {ctx.author}.") +            with suppress(NotFound): +                self.mod_log.ignore(Event.message_delete, ctx.message.id) +                await ctx.message.delete()      @command(name='subscribe')      @in_channel(Channels.bot) | 
