Browse Source

[commands] Provide a way to retrieve time left for a cooldown

pull/5212/head
Dan Hess 5 years ago
committed by GitHub
parent
commit
3a9fd00a1a
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 9
      discord/ext/commands/cooldowns.py
  2. 26
      discord/ext/commands/core.py

9
discord/ext/commands/cooldowns.py

@ -91,6 +91,15 @@ class Cooldown:
tokens = self.rate
return tokens
def get_retry_after(self, current=None):
current = current or time.time()
tokens = self.get_tokens(current)
if tokens == 0:
return self.per - (current - self._window)
return 0.0
def update_rate_limit(self, current=None):
current = current or time.time()
self._last = current

26
discord/ext/commands/core.py

@ -805,7 +805,8 @@ class Command(_BaseCommand):
return False
bucket = self._buckets.get_bucket(ctx.message)
return bucket.get_tokens() == 0
current = ctx.message.created_at.replace(tzinfo=datetime.timezone.utc).timestamp()
return bucket.get_tokens(current) == 0
def reset_cooldown(self, ctx):
"""Resets the cooldown on this command.
@ -819,6 +820,29 @@ class Command(_BaseCommand):
bucket = self._buckets.get_bucket(ctx.message)
bucket.reset()
def get_cooldown_retry_after(self, ctx):
"""Retrieves the amount of seconds before this command can be tried again.
.. versionadded:: 1.4
Parameters
-----------
ctx: :class:`.Context`
The invocation context to retrieve the cooldown from.
Returns
--------
:class:`float`
The amount of time left on this command's cooldown in seconds.
If this is ``0.0`` then the command isn't on cooldown.
"""
if self._buckets.valid:
bucket = self._buckets.get_bucket(ctx.message)
current = ctx.message.created_at.replace(tzinfo=datetime.timezone.utc).timestamp()
return bucket.get_retry_after(current)
return 0.0
async def invoke(self, ctx):
await self.prepare(ctx)

Loading…
Cancel
Save