aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArjun Satarkar <me@arjunsatarkar.net>2023-12-21 12:36:57 +0000
committerArjun Satarkar <me@arjunsatarkar.net>2023-12-21 12:36:57 +0000
commit244738893f9a933cc681c193ee594811ad89ec5d (patch)
treec7ec952464f4f2879ea7e04696bdad87d3796b26
parent4d905d103cbaf568fecc097f13f66f843d5c7282 (diff)
downloadaps-cogs-244738893f9a933cc681c193ee594811ad89ec5d.tar
aps-cogs-244738893f9a933cc681c193ee594811ad89ec5d.tar.gz
aps-cogs-244738893f9a933cc681c193ee594811ad89ec5d.zip
question_of_the_day: automatically pin the new QOTD and unpin the old
-rw-r--r--question_of_the_day/question_of_the_day.py46
1 files changed, 37 insertions, 9 deletions
diff --git a/question_of_the_day/question_of_the_day.py b/question_of_the_day/question_of_the_day.py
index fe48e28..46cf1e6 100644
--- a/question_of_the_day/question_of_the_day.py
+++ b/question_of_the_day/question_of_the_day.py
@@ -27,6 +27,7 @@ class QuestionOfTheDay(commands.Cog):
post_at={"hour": 0, "minute": 0},
post_in_channel=None,
enabled=False,
+ latest_qotd_message_info={"channel_id": None, "message_id": None},
)
self.config.register_global(last_posted_qotds_at=None, guild_to_post_at={})
self.post_qotds.start()
@@ -53,6 +54,7 @@ class QuestionOfTheDay(commands.Cog):
)
channel = await guild.fetch_channel(channel_id)
await self.post_question(channel)
+
current_time = time.time()
current_datetime = datetime.datetime.fromtimestamp(
@@ -179,8 +181,11 @@ class QuestionOfTheDay(commands.Cog):
"""
Set the current channel as where QOTDs should be posted.
"""
- await self.config.guild(ctx.guild).post_in_channel.set(ctx.channel.id)
- await ctx.reply("Questions of the day will be posted in this channel.")
+ if isinstance(ctx.channel, discord.TextChannel):
+ await self.config.guild(ctx.guild).post_in_channel.set(ctx.channel.id)
+ await ctx.reply("Questions of the day will be posted in this channel.")
+ else:
+ await ctx.reply("Error: must use a text channel.")
@qotd.command()
@checks.admin_or_permissions(manage_server=True)
@@ -291,26 +296,49 @@ class QuestionOfTheDay(commands.Cog):
except IndexError:
await ctx.reply(f"Error: no suggestion with id {suggestion_id}.")
- async def post_question (self, channel):
+ async def post_question(self, channel):
guild = channel.guild
async with self.config.guild(guild).questions() as questions:
questions_len = len(questions)
if not questions_len:
- await channel.send(
- "# Question of the Day\n**No questions left!**"
- )
+ await channel.send("# Question of the Day\n**No questions left!**")
else:
question_index = random.randrange(0, questions_len)
question = questions[question_index]
- await channel.send(
+ message = await channel.send(
f"# Question of the Day\n"
f"{question['question']}\n{redbot.core.utils.chat_formatting.italics((await guild.fetch_member(question['asked_by'])).name)}"
f" ({question['asked_by']})"
)
del questions[question_index]
- self.logger.info(
- f"Posted QOTD for guild {guild.name} ({guild.id})."
+ await self.manage_qotd_pins(message)
+ self.logger.info(f"Posted QOTD for guild {guild.name} ({guild.id}).")
+
+ async def manage_qotd_pins(self, new_message):
+ guild = new_message.guild
+ async with self.config.guild(
+ guild
+ ).latest_qotd_message_info() as latest_qotd_message_info:
+ if (
+ latest_qotd_message_info["channel_id"] is not None
+ and latest_qotd_message_info["message_id"] is not None
+ ):
+ channel = await guild.fetch_channel(
+ latest_qotd_message_info["channel_id"]
+ )
+ old_message = await channel.fetch_message(
+ latest_qotd_message_info["message_id"]
)
+ try:
+ await old_message.unpin(reason="Unpinning old question of the day.")
+ except (discord.Forbidden, discord.NotFound):
+ pass
+ try:
+ await new_message.pin(reason="Pinning new question of the day.")
+ except (discord.Forbidden, discord.NotFound):
+ pass
+ latest_qotd_message_info["channel_id"] = new_message.channel.id
+ latest_qotd_message_info["message_id"] = new_message.id
async def paginate_questions(self, ctx, questions: list):
return [