aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar MarkKoz <[email protected]>2021-01-03 20:07:22 -0800
committerGravatar MarkKoz <[email protected]>2021-01-04 23:20:00 -0800
commitd98a34ff042418c93b50f4128d16a0847b479083 (patch)
tree3c4259bc574616b55391e73eea78c5a00bb5fc9b
parentHelpChannels: make a channel available within the lock (diff)
HelpChannels: refactor the close command check
-rw-r--r--bot/exts/help_channels/_cog.py20
1 files changed, 10 insertions, 10 deletions
diff --git a/bot/exts/help_channels/_cog.py b/bot/exts/help_channels/_cog.py
index e99dd92db..a15e6295e 100644
--- a/bot/exts/help_channels/_cog.py
+++ b/bot/exts/help_channels/_cog.py
@@ -154,8 +154,12 @@ class HelpChannels(commands.Cog):
log.debug(f"Creating a new dormant channel named {name}.")
return await self.dormant_category.create_text_channel(name, topic=HELP_CHANNEL_TOPIC)
- async def dormant_check(self, ctx: commands.Context) -> bool:
- """Return True if the user is the help channel claimant or passes the role check."""
+ async def close_check(self, ctx: commands.Context) -> bool:
+ """Return True if the channel is in use and the user is the claimant or has a whitelisted role."""
+ if ctx.channel.category != self.in_use_category:
+ log.debug(f"{ctx.author} invoked command 'close' outside an in-use help channel")
+ return False
+
if await _caches.claimants.get(ctx.channel.id) == ctx.author.id:
log.trace(f"{ctx.author} is the help channel claimant, passing the check for dormant.")
self.bot.stats.incr("help.dormant_invoke.claimant")
@@ -174,16 +178,12 @@ class HelpChannels(commands.Cog):
"""
Make the current in-use help channel dormant.
- Make the channel dormant if the user passes the `dormant_check`,
+ Make the channel dormant if the user passes the `close_check`,
delete the message that invoked this.
"""
- log.trace("close command invoked; checking if the channel is in-use.")
-
- if ctx.channel.category != self.in_use_category:
- log.debug(f"{ctx.author} invoked command 'dormant' outside an in-use help channel")
- return
-
- if await self.dormant_check(ctx):
+ # Don't use a discord.py check because the check needs to fail silently.
+ if await self.close_check(ctx):
+ log.info(f"Close command invoked by {ctx.author} in #{ctx.channel}.")
await self.unclaim_channel(ctx.channel, "command")
self.scheduler.cancel(ctx.channel.id)