From cbbfc733e7f2a2ae7cd1f946c8c3da94a521c258 Mon Sep 17 00:00:00 2001 From: kraktus <56031107+kraktus@users.noreply.github.com> Date: Sat, 5 Oct 2019 13:32:23 +0200 Subject: Added a new `periodic_ping` to fix #320 Created a new function named `periodic_ping` in `verification.py`, using `discord.ext.tasks` and `datetime` module. Every hour the function checks if the last message in the channel (ie last message of the bot) is older than a week. If so, it deletes this message and post a new one. --- bot/cogs/verification.py | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/bot/cogs/verification.py b/bot/cogs/verification.py index f0a099f27..588037d45 100644 --- a/bot/cogs/verification.py +++ b/bot/cogs/verification.py @@ -1,6 +1,8 @@ import logging +from datetime import datetime from discord import Message, NotFound, Object +from discord.ext import tasks from discord.ext.commands import Bot, Cog, Context, command from bot.cogs.modlog import ModLog @@ -27,12 +29,16 @@ from time to time, you can send `!subscribe` to <#{Channels.bot}> at any time to If you'd like to unsubscribe from the announcement notifications, simply send `!unsubscribe` to <#{Channels.bot}>. """ +PERIODIC_PING = (f"@everyone To verify that you have read our rules, please type `!accept`." + f" Ping <@&{Roles.admin}> if you encounter any problems during the verification process.") + class Verification(Cog): """User verification and role self-management.""" def __init__(self, bot: Bot): self.bot = bot + self.periodic_ping.start() @property def mod_log(self) -> ModLog: @@ -155,6 +161,20 @@ class Verification(Cog): else: return True + @tasks.loop(hours=1.0) + async def periodic_ping(self) -> None: + """Post a recap message every week with an @everyone.""" + message = await self.bot.get_channel(Channels.verification).history(limit=1).flatten() # check last message + delta = datetime.utcnow() - message[0].created_at # time since last periodic ping + if delta.days >= 7: # if the message is older than a week + await message[0].delete() + await self.bot.get_channel(Channels.verification).send(PERIODIC_PING) + + @periodic_ping.before_loop + async def before_ping(self) -> None: + """Only start the loop when the bot is ready.""" + await self.bot.wait_until_ready() + def setup(bot: Bot) -> None: """Verification cog load.""" -- cgit v1.2.3