summaryrefslogtreecommitdiffstats
path: root/botcore/utils
diff options
context:
space:
mode:
authorGravatar Hassan Abouelela <[email protected]>2022-07-23 15:50:44 +0200
committerGravatar GitHub <[email protected]>2022-07-23 15:50:44 +0200
commit2d7f51e990666c37cffb5f2a2e4d60d0457d3bc6 (patch)
tree8a298eb66495d2bae6890a3082042fdac0b802ca /botcore/utils
parentMerge PR #105: Correctly determine source modules for re-exported symbols (diff)
parentMerge branch 'main' into bot-core-100 (diff)
Merge pull request #101 from python-discord/bot-core-100
Add `clean_text_or_reply` util.
Diffstat (limited to 'botcore/utils')
-rw-r--r--botcore/utils/__init__.py3
-rw-r--r--botcore/utils/commands.py38
2 files changed, 40 insertions, 1 deletions
diff --git a/botcore/utils/__init__.py b/botcore/utils/__init__.py
index dfdd6df5..95e89d20 100644
--- a/botcore/utils/__init__.py
+++ b/botcore/utils/__init__.py
@@ -1,6 +1,6 @@
"""Useful utilities and tools for Discord bot development."""
-from botcore.utils import _monkey_patches, caching, channel, interactions, logging, members, regex, scheduling
+from botcore.utils import _monkey_patches, caching, channel, commands, interactions, logging, members, regex, scheduling
from botcore.utils._extensions import unqualify
@@ -24,6 +24,7 @@ __all__ = [
apply_monkey_patches,
caching,
channel,
+ commands,
interactions,
logging,
members,
diff --git a/botcore/utils/commands.py b/botcore/utils/commands.py
new file mode 100644
index 00000000..7afd8137
--- /dev/null
+++ b/botcore/utils/commands.py
@@ -0,0 +1,38 @@
+from typing import Optional
+
+from discord import Message
+from discord.ext.commands import BadArgument, Context, clean_content
+
+
+async def clean_text_or_reply(ctx: Context, text: Optional[str] = None) -> str:
+ """
+ Cleans a text argument or replied message's content.
+
+ Args:
+ ctx: The command's context
+ text: The provided text argument of the command (if given)
+
+ Raises:
+ :exc:`discord.ext.commands.BadArgument`
+ `text` wasn't provided and there's no reply message / reply message content.
+
+ Returns:
+ The cleaned version of `text`, if given, else replied message.
+ """
+ clean_content_converter = clean_content(fix_channel_mentions=True)
+
+ if text:
+ return await clean_content_converter.convert(ctx, text)
+
+ if (
+ (replied_message := getattr(ctx.message.reference, "resolved", None)) # message has a cached reference
+ and isinstance(replied_message, Message) # referenced message hasn't been deleted
+ ):
+ if not (content := ctx.message.reference.resolved.content):
+ # The referenced message doesn't have a content (e.g. embed/image), so raise error
+ raise BadArgument("The referenced message doesn't have a text content.")
+
+ return await clean_content_converter.convert(ctx, content)
+
+ # No text provided, and either no message was referenced or we can't access the content
+ raise BadArgument("Couldn't find text to clean. Provide a string or reply to a message to use its content.")