mirror of
https://github.com/Cog-Creators/Red-DiscordBot.git
synced 2025-11-06 03:08:55 -05:00
Only accept positive integers in [p]cleanup commands (#4115)
This commit is contained in:
parent
d73ad3115f
commit
8ada1ee152
@ -1,6 +1,6 @@
|
||||
import logging
|
||||
from datetime import datetime, timedelta
|
||||
from typing import Union, List, Callable, Set
|
||||
from typing import Callable, List, Optional, Set, Union
|
||||
|
||||
import discord
|
||||
|
||||
@ -10,7 +10,7 @@ from redbot.core.i18n import Translator, cog_i18n
|
||||
from redbot.core.utils.chat_formatting import humanize_number
|
||||
from redbot.core.utils.mod import slow_deletion, mass_purge
|
||||
from redbot.core.utils.predicates import MessagePredicate
|
||||
from .converters import RawMessageIds
|
||||
from .converters import PositiveInt, RawMessageIds, positive_int
|
||||
|
||||
_ = Translator("Cleanup", __file__)
|
||||
|
||||
@ -60,9 +60,9 @@ class Cleanup(commands.Cog):
|
||||
async def get_messages_for_deletion(
|
||||
*,
|
||||
channel: discord.TextChannel,
|
||||
number: int = None,
|
||||
number: Optional[PositiveInt] = None,
|
||||
check: Callable[[discord.Message], bool] = lambda x: True,
|
||||
limit: int = None,
|
||||
limit: Optional[PositiveInt] = None,
|
||||
before: Union[discord.Message, datetime] = None,
|
||||
after: Union[discord.Message, datetime] = None,
|
||||
delete_pinned: bool = False,
|
||||
@ -105,7 +105,7 @@ class Cleanup(commands.Cog):
|
||||
break
|
||||
if message_filter(message):
|
||||
collected.append(message)
|
||||
if number and number <= len(collected):
|
||||
if number is not None and number <= len(collected):
|
||||
break
|
||||
|
||||
return collected
|
||||
@ -120,7 +120,7 @@ class Cleanup(commands.Cog):
|
||||
@commands.guild_only()
|
||||
@commands.bot_has_permissions(manage_messages=True)
|
||||
async def text(
|
||||
self, ctx: commands.Context, text: str, number: int, delete_pinned: bool = False
|
||||
self, ctx: commands.Context, text: str, number: positive_int, delete_pinned: bool = False
|
||||
):
|
||||
"""Delete the last X messages matching the specified text.
|
||||
|
||||
@ -169,7 +169,7 @@ class Cleanup(commands.Cog):
|
||||
@commands.guild_only()
|
||||
@commands.bot_has_permissions(manage_messages=True)
|
||||
async def user(
|
||||
self, ctx: commands.Context, user: str, number: int, delete_pinned: bool = False
|
||||
self, ctx: commands.Context, user: str, number: positive_int, delete_pinned: bool = False
|
||||
):
|
||||
"""Delete the last X messages from a specified user.
|
||||
|
||||
@ -270,7 +270,7 @@ class Cleanup(commands.Cog):
|
||||
self,
|
||||
ctx: commands.Context,
|
||||
message_id: RawMessageIds,
|
||||
number: int,
|
||||
number: positive_int,
|
||||
delete_pinned: bool = False,
|
||||
):
|
||||
"""Deletes X messages before specified message.
|
||||
@ -351,7 +351,9 @@ class Cleanup(commands.Cog):
|
||||
@cleanup.command()
|
||||
@commands.guild_only()
|
||||
@commands.bot_has_permissions(manage_messages=True)
|
||||
async def messages(self, ctx: commands.Context, number: int, delete_pinned: bool = False):
|
||||
async def messages(
|
||||
self, ctx: commands.Context, number: positive_int, delete_pinned: bool = False
|
||||
):
|
||||
"""Delete the last X messages.
|
||||
|
||||
Example:
|
||||
@ -381,7 +383,9 @@ class Cleanup(commands.Cog):
|
||||
@cleanup.command(name="bot")
|
||||
@commands.guild_only()
|
||||
@commands.bot_has_permissions(manage_messages=True)
|
||||
async def cleanup_bot(self, ctx: commands.Context, number: int, delete_pinned: bool = False):
|
||||
async def cleanup_bot(
|
||||
self, ctx: commands.Context, number: positive_int, delete_pinned: bool = False
|
||||
):
|
||||
"""Clean up command messages and messages from the bot."""
|
||||
|
||||
channel = ctx.channel
|
||||
@ -458,7 +462,7 @@ class Cleanup(commands.Cog):
|
||||
async def cleanup_self(
|
||||
self,
|
||||
ctx: commands.Context,
|
||||
number: int,
|
||||
number: positive_int,
|
||||
match_pattern: str = None,
|
||||
delete_pinned: bool = False,
|
||||
):
|
||||
@ -531,7 +535,7 @@ class Cleanup(commands.Cog):
|
||||
@cleanup.command(name="spam")
|
||||
@commands.guild_only()
|
||||
@commands.bot_has_permissions(manage_messages=True)
|
||||
async def cleanup_spam(self, ctx: commands.Context, number: int = 50):
|
||||
async def cleanup_spam(self, ctx: commands.Context, number: positive_int = PositiveInt(50)):
|
||||
"""Deletes duplicate messages in the channel from the last X messages and keeps only one copy.
|
||||
|
||||
Defaults to 50.
|
||||
|
||||
@ -1,12 +1,30 @@
|
||||
from redbot.core.commands import Converter, BadArgument
|
||||
from typing import NewType, TYPE_CHECKING
|
||||
|
||||
from redbot.core.commands import BadArgument, Context, Converter
|
||||
from redbot.core.i18n import Translator
|
||||
from redbot.core.utils.chat_formatting import inline
|
||||
|
||||
_ = Translator("Cleanup", __file__)
|
||||
|
||||
|
||||
class RawMessageIds(Converter):
|
||||
async def convert(self, ctx, argument):
|
||||
async def convert(self, ctx: Context, argument: str) -> int:
|
||||
if argument.isnumeric() and len(argument) >= 17:
|
||||
return int(argument)
|
||||
|
||||
raise BadArgument(_("{} doesn't look like a valid message ID.").format(argument))
|
||||
|
||||
|
||||
PositiveInt = NewType("PositiveInt", int)
|
||||
if TYPE_CHECKING:
|
||||
positive_int = PositiveInt
|
||||
else:
|
||||
|
||||
def positive_int(arg: str) -> int:
|
||||
try:
|
||||
ret = int(arg)
|
||||
except ValueError:
|
||||
raise BadArgument(_("{arg} is not an integer.").format(arg=inline(arg)))
|
||||
if ret <= 0:
|
||||
raise BadArgument(_("{arg} is not a positive integer.").format(arg=inline(arg)))
|
||||
return ret
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user