diff options
| author | 2021-01-29 19:51:53 +0300 | |
|---|---|---|
| committer | 2021-01-29 19:51:53 +0300 | |
| commit | 0bd9ae533442f4eb651c5757ee4c25ffc0cd1c62 (patch) | |
| tree | f7d93433ccaf9ed2ebd843368767f0e545be14c5 | |
| parent | Merge pull request #1372 from anand2312/duckpond-check (diff) | |
| parent | Merge branch 'master' into trashcan-mods (diff) | |
Merge pull request #1358 from python-discord/trashcan-mods
Make sure that moderators can interact with trashcans and restrict paginator usage
| -rw-r--r-- | bot/pagination.py | 14 | ||||
| -rw-r--r-- | bot/utils/messages.py | 6 | 
2 files changed, 16 insertions, 4 deletions
| diff --git a/bot/pagination.py b/bot/pagination.py index 182b2fa76..3b16cc9ff 100644 --- a/bot/pagination.py +++ b/bot/pagination.py @@ -4,10 +4,12 @@ import typing as t  from contextlib import suppress  import discord +from discord import Member  from discord.abc import User  from discord.ext.commands import Context, Paginator  from bot import constants +from bot.constants import MODERATION_ROLES  FIRST_EMOJI = "\u23EE"   # [:track_previous:]  LEFT_EMOJI = "\u2B05"    # [:arrow_left:] @@ -210,6 +212,9 @@ class LinePaginator(Paginator):          Pagination will also be removed automatically if no reaction is added for five minutes (300 seconds). +        The interaction will be limited to `restrict_to_user` (ctx.author by default) or +        to any user with a moderation role. +          Example:          >>> embed = discord.Embed()          >>> embed.set_author(name="Some Operation", url=url, icon_url=icon) @@ -218,10 +223,10 @@ class LinePaginator(Paginator):          def event_check(reaction_: discord.Reaction, user_: discord.Member) -> bool:              """Make sure that this reaction is what we want to operate on."""              no_restrictions = ( -                # Pagination is not restricted -                not restrict_to_user                  # The reaction was by a whitelisted user -                or user_.id == restrict_to_user.id +                user_.id == restrict_to_user.id +                # The reaction was by a moderator +                or isinstance(user_, Member) and any(role.id in MODERATION_ROLES for role in user_.roles)              )              return ( @@ -242,6 +247,9 @@ class LinePaginator(Paginator):                          scale_to_size=scale_to_size)          current_page = 0 +        if not restrict_to_user: +            restrict_to_user = ctx.author +          if not lines:              if exception_on_empty_embed:                  log.exception("Pagination asked for empty lines iterable") diff --git a/bot/utils/messages.py b/bot/utils/messages.py index 42bde358d..832ad4d55 100644 --- a/bot/utils/messages.py +++ b/bot/utils/messages.py @@ -11,7 +11,7 @@ from discord.errors import HTTPException  from discord.ext.commands import Context  import bot -from bot.constants import Emojis, NEGATIVE_REPLIES +from bot.constants import Emojis, MODERATION_ROLES, NEGATIVE_REPLIES  log = logging.getLogger(__name__) @@ -22,12 +22,15 @@ async def wait_for_deletion(      deletion_emojis: Sequence[str] = (Emojis.trashcan,),      timeout: float = 60 * 5,      attach_emojis: bool = True, +    allow_moderation_roles: bool = True  ) -> None:      """      Wait for up to `timeout` seconds for a reaction by any of the specified `user_ids` to delete the message.      An `attach_emojis` bool may be specified to determine whether to attach the given      `deletion_emojis` to the message in the given `context`. +    An `allow_moderation_roles` bool may also be specified to allow anyone with a role in `MODERATION_ROLES` to delete +    the message.      """      if message.guild is None:          raise ValueError("Message must be sent on a guild") @@ -46,6 +49,7 @@ async def wait_for_deletion(              reaction.message.id == message.id              and str(reaction.emoji) in deletion_emojis              and user.id in user_ids +            or allow_moderation_roles and any(role.id in MODERATION_ROLES for role in user.roles)          )      with contextlib.suppress(asyncio.TimeoutError): | 
