diff options
| author | 2019-12-11 18:13:05 -0800 | |
|---|---|---|
| committer | 2019-12-11 18:13:05 -0800 | |
| commit | 7130de271ddfde568d2d008823656e5371b4dc45 (patch) | |
| tree | 8f36cd188bfb4a9a1683e15f5b7ecc39b46b7feb | |
| parent | Clean: un-hide from help and add purge alias (diff) | |
Clean: support specifying a channel different than the context's
| -rw-r--r-- | bot/cogs/clean.py | 31 | 
1 files changed, 18 insertions, 13 deletions
diff --git a/bot/cogs/clean.py b/bot/cogs/clean.py index a45d30142..312c7926d 100644 --- a/bot/cogs/clean.py +++ b/bot/cogs/clean.py @@ -3,7 +3,7 @@ import random  import re  from typing import Optional -from discord import Colour, Embed, Message, User +from discord import Colour, Embed, Message, TextChannel, User  from discord.ext.commands import Bot, Cog, Context, group  from bot.cogs.moderation import ModLog @@ -39,7 +39,8 @@ class Clean(Cog):      async def _clean_messages(              self, amount: int, ctx: Context,              bots_only: bool = False, user: User = None, -            regex: Optional[str] = None +            regex: Optional[str] = None, +            channel: Optional[TextChannel] = None      ) -> None:          """A helper function that does the actual message cleaning."""          def predicate_bots_only(message: Message) -> bool: @@ -104,6 +105,10 @@ class Clean(Cog):          else:              predicate = None                     # Delete all messages +        # Default to using the invoking context's channel +        if not channel: +            channel = ctx.channel +          # Look through the history and retrieve message data          messages = []          message_ids = [] @@ -111,7 +116,7 @@ class Clean(Cog):          invocation_deleted = False          # To account for the invocation message, we index `amount + 1` messages. -        async for message in ctx.channel.history(limit=amount + 1): +        async for message in channel.history(limit=amount + 1):              # If at any point the cancel command is invoked, we should stop.              if not self.cleaning: @@ -135,7 +140,7 @@ class Clean(Cog):          self.mod_log.ignore(Event.message_delete, *message_ids)          # Use bulk delete to actually do the cleaning. It's far faster. -        await ctx.channel.purge( +        await channel.purge(              limit=amount,              check=predicate          ) @@ -155,7 +160,7 @@ class Clean(Cog):          # Build the embed and send it          message = ( -            f"**{len(message_ids)}** messages deleted in <#{ctx.channel.id}> by **{ctx.author.name}**\n\n" +            f"**{len(message_ids)}** messages deleted in <#{channel.id}> by **{ctx.author.name}**\n\n"              f"A log of the deleted messages can be found [here]({log_url})."          ) @@ -175,27 +180,27 @@ class Clean(Cog):      @clean_group.command(name="user", aliases=["users"])      @with_role(*MODERATION_ROLES) -    async def clean_user(self, ctx: Context, user: User, amount: int = 10) -> None: +    async def clean_user(self, ctx: Context, user: User, amount: int = 10, channel: TextChannel = None) -> None:          """Delete messages posted by the provided user, stop cleaning after traversing `amount` messages.""" -        await self._clean_messages(amount, ctx, user=user) +        await self._clean_messages(amount, ctx, user=user, channel=channel)      @clean_group.command(name="all", aliases=["everything"])      @with_role(*MODERATION_ROLES) -    async def clean_all(self, ctx: Context, amount: int = 10) -> None: +    async def clean_all(self, ctx: Context, amount: int = 10, channel: TextChannel = None) -> None:          """Delete all messages, regardless of poster, stop cleaning after traversing `amount` messages.""" -        await self._clean_messages(amount, ctx) +        await self._clean_messages(amount, ctx, channel=channel)      @clean_group.command(name="bots", aliases=["bot"])      @with_role(*MODERATION_ROLES) -    async def clean_bots(self, ctx: Context, amount: int = 10) -> None: +    async def clean_bots(self, ctx: Context, amount: int = 10, channel: TextChannel = None) -> None:          """Delete all messages posted by a bot, stop cleaning after traversing `amount` messages.""" -        await self._clean_messages(amount, ctx, bots_only=True) +        await self._clean_messages(amount, ctx, bots_only=True, channel=channel)      @clean_group.command(name="regex", aliases=["word", "expression"])      @with_role(*MODERATION_ROLES) -    async def clean_regex(self, ctx: Context, regex: str, amount: int = 10) -> None: +    async def clean_regex(self, ctx: Context, regex: str, amount: int = 10, channel: TextChannel = None) -> None:          """Delete all messages that match a certain regex, stop cleaning after traversing `amount` messages.""" -        await self._clean_messages(amount, ctx, regex=regex) +        await self._clean_messages(amount, ctx, regex=regex, channel=channel)      @clean_group.command(name="stop", aliases=["cancel", "abort"])      @with_role(*MODERATION_ROLES)  |