aboutsummaryrefslogtreecommitdiffstats
path: root/bot
diff options
context:
space:
mode:
authorGravatar scragly <[email protected]>2020-09-19 01:54:07 +1000
committerGravatar GitHub <[email protected]>2020-09-19 01:54:07 +1000
commit21150798337a15b956a46751ffab54d163423835 (patch)
tree9a2b74b022d25026b56ae2a7e9bf4c96c6ecfbb0 /bot
parentMerge pull request #421 from PureFunctor/caesar-command (diff)
parentStop users from viewing messages they shouldn't. (diff)
Merge pull request #443 from python-discord/bug/message-convert-fix
Stop users from viewing messages they shouldn't.
Diffstat (limited to 'bot')
-rw-r--r--bot/exts/evergreen/fun.py16
1 files changed, 10 insertions, 6 deletions
diff --git a/bot/exts/evergreen/fun.py b/bot/exts/evergreen/fun.py
index 2f575c1c..e6cdf716 100644
--- a/bot/exts/evergreen/fun.py
+++ b/bot/exts/evergreen/fun.py
@@ -181,18 +181,22 @@ class Fun(Cog):
"""
Attempts to extract the text and embed from a possible link to a discord Message.
+ Does not retrieve the text and embed from the Message if it is in a channel the user does
+ not have read permissions in.
+
Returns a tuple of:
str: If `text` is a valid discord Message, the contents of the message, else `text`.
Union[Embed, None]: The embed if found in the valid Message, else None
"""
embed = None
- # message = await Fun._get_discord_message(ctx, text)
- # if isinstance(message, Message):
- # text = message.content
- # # Take first embed because we can't send multiple embeds
- # if message.embeds:
- # embed = message.embeds[0]
+ msg = await Fun._get_discord_message(ctx, text)
+ # Ensure the user has read permissions for the channel the message is in
+ if isinstance(msg, Message) and ctx.author.permissions_in(msg.channel).read_messages:
+ text = msg.content
+ # Take first embed because we can't send multiple embeds
+ if msg.embeds:
+ embed = msg.embeds[0]
return (text, embed)