diff options
| author | 2019-08-06 00:39:25 +0800 | |
|---|---|---|
| committer | 2019-08-06 00:39:25 +0800 | |
| commit | ef95acda7c8511de52d125d6f355be89984b1bfe (patch) | |
| tree | 12c4ef87bcec20e01a73470146fb2a334b980f9a | |
| parent | Add global check to SeasonalBot (diff) | |
Implement error handling; add `in_channel` overrides to `!issue` and AoC commands
| -rw-r--r-- | bot/seasons/christmas/adventofcode.py | 2 | ||||
| -rw-r--r-- | bot/seasons/evergreen/error_handler.py | 15 | ||||
| -rw-r--r-- | bot/seasons/evergreen/issues.py | 2 | 
3 files changed, 19 insertions, 0 deletions
| diff --git a/bot/seasons/christmas/adventofcode.py b/bot/seasons/christmas/adventofcode.py index 08b07e83..a9e72805 100644 --- a/bot/seasons/christmas/adventofcode.py +++ b/bot/seasons/christmas/adventofcode.py @@ -14,6 +14,7 @@ from discord.ext import commands  from pytz import timezone  from bot.constants import AdventOfCode as AocConfig, Channels, Colours, Emojis, Tokens +from bot.decorators import override_in_channel  log = logging.getLogger(__name__) @@ -125,6 +126,7 @@ class AdventOfCode(commands.Cog):          self.status_task = asyncio.ensure_future(self.bot.loop.create_task(status_coro))      @commands.group(name="adventofcode", aliases=("aoc",), invoke_without_command=True) +    @override_in_channel      async def adventofcode_group(self, ctx: commands.Context):          """All of the Advent of Code commands."""          await ctx.send_help(ctx.command) diff --git a/bot/seasons/evergreen/error_handler.py b/bot/seasons/evergreen/error_handler.py index f4457f8f..6690cf89 100644 --- a/bot/seasons/evergreen/error_handler.py +++ b/bot/seasons/evergreen/error_handler.py @@ -1,10 +1,15 @@  import logging
  import math
 +import random
  import sys
  import traceback
 +from discord import Colour, Embed
  from discord.ext import commands
 +from bot.constants import NEGATIVE_REPLIES
 +from bot.decorators import InChannelCheckFailure
 +
  log = logging.getLogger(__name__)
 @@ -34,6 +39,16 @@ class CommandErrorHandler(commands.Cog):          error = getattr(error, 'original', error)
 +        if isinstance(error, InChannelCheckFailure):
 +            logging.debug(
 +                f"{ctx.author} the command '{ctx.command}', but they did not have "
 +                f"permissions to run commands in the channel {ctx.channel}!"
 +            )
 +            embed = Embed(colour=Colour.red())
 +            embed.title = random.choice(NEGATIVE_REPLIES)
 +            embed.description = str(error)
 +            return await ctx.send(embed=embed)
 +
          if isinstance(error, commands.CommandNotFound):
              return logging.debug(
                  f"{ctx.author} called '{ctx.message.content}' but no command was found."
 diff --git a/bot/seasons/evergreen/issues.py b/bot/seasons/evergreen/issues.py index 2a31a2e1..f19a1129 100644 --- a/bot/seasons/evergreen/issues.py +++ b/bot/seasons/evergreen/issues.py @@ -4,6 +4,7 @@ import discord  from discord.ext import commands  from bot.constants import Colours +from bot.decorators import override_in_channel  log = logging.getLogger(__name__) @@ -15,6 +16,7 @@ class Issues(commands.Cog):          self.bot = bot      @commands.command(aliases=("issues",)) +    @override_in_channel      async def issue(self, ctx, number: int, repository: str = "seasonalbot", user: str = "python-discord"):          """Command to retrieve issues from a GitHub repository."""          api_url = f"https://api.github.com/repos/{user}/{repository}/issues/{number}" | 
