aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Chris Lovering <[email protected]>2021-07-28 17:59:04 +0100
committerGravatar Chris Lovering <[email protected]>2021-07-28 17:59:04 +0100
commited352272a67224182178bbd5583746053ec912a6 (patch)
tree24874ec6cc40cbbc1e0842248adc247244872faa
parentsimplify range predicate for clean command (diff)
Rely on error handler for sending input errors to user
-rw-r--r--bot/exts/utils/clean.py54
1 files changed, 9 insertions, 45 deletions
diff --git a/bot/exts/utils/clean.py b/bot/exts/utils/clean.py
index 847ac5c86..7514c7a64 100644
--- a/bot/exts/utils/clean.py
+++ b/bot/exts/utils/clean.py
@@ -1,5 +1,4 @@
import logging
-import random
import re
import time
from collections import defaultdict
@@ -8,10 +7,11 @@ from typing import Any, Callable, DefaultDict, Iterable, List, Optional, Tuple
from discord import Colour, Embed, Message, NotFound, TextChannel, User, errors
from discord.ext import commands
from discord.ext.commands import Cog, Context, group, has_any_role
+from discord.ext.commands.errors import BadArgument, MaxConcurrencyReached, MissingRequiredArgument
from bot.bot import Bot
from bot.constants import (
- Channels, CleanMessages, Colours, Event, Icons, MODERATION_ROLES, NEGATIVE_REPLIES
+ Channels, CleanMessages, Colours, Event, Icons, MODERATION_ROLES
)
from bot.exts.moderation.modlog import ModLog
from bot.utils.channel import is_mod_channel
@@ -168,55 +168,24 @@ class Clean(Cog):
# Is this an acceptable amount of messages to clean?
if amount > CleanMessages.message_limit:
- embed = Embed(
- color=Colour(Colours.soft_red),
- title=random.choice(NEGATIVE_REPLIES),
- description=f"You cannot clean more than {CleanMessages.message_limit} messages."
- )
- await ctx.send(embed=embed)
- return
+ raise BadArgument(f"You cannot clean more than {CleanMessages.message_limit} messages.")
if after_message:
-
# Ensure that until_message is specified.
if not until_message:
- embed = Embed(
- color=Colour(Colours.soft_red),
- title=random.choice(NEGATIVE_REPLIES),
- description="`until_message` must be specified if `after_message` is specified."
- )
- await ctx.send(embed=embed)
- return
+ raise MissingRequiredArgument("`until_message` must be specified if `after_message` is specified.")
- # Check if the messages are not in same channel
+ # Messages are not in same channel
if after_message.channel != until_message.channel:
- embed = Embed(
- color=Colour(Colours.soft_red),
- title=random.choice(NEGATIVE_REPLIES),
- description="You cannot do range clean across several channel."
- )
- await ctx.send(embed=embed)
- return
+ raise BadArgument("You cannot do range clean across several channel.")
# Ensure that after_message is younger than until_message
if after_message.created_at >= until_message.created_at:
- embed = Embed(
- color=Colour(Colours.soft_red),
- title=random.choice(NEGATIVE_REPLIES),
- description="`after` message must be younger than `until` message"
- )
- await ctx.send(embed=embed)
- return
+ raise BadArgument("`after` message must be younger than `until` message")
# Are we already performing a clean?
if self.cleaning:
- embed = Embed(
- color=Colour(Colours.soft_red),
- title=random.choice(NEGATIVE_REPLIES),
- description="Please wait for the currently ongoing clean operation to complete."
- )
- await ctx.send(embed=embed)
- return
+ raise MaxConcurrencyReached("Please wait for the currently ongoing clean operation to complete.")
# Set up the correct predicate
if bots_only:
@@ -305,12 +274,7 @@ class Clean(Cog):
log_url = await self.mod_log.upload_log(log_messages, ctx.author.id)
else:
# Can't build an embed, nothing to clean!
- embed = Embed(
- color=Colour(Colours.soft_red),
- description="No matching messages could be found."
- )
- await ctx.send(embed=embed, delete_after=10)
- return
+ raise BadArgument("No matching messages could be found.")
# Build the embed and send it
target_channels = ", ".join(channel.mention for channel in channels)