From 760102edf772b9a0eee90eadc2bf2225b50eb963 Mon Sep 17 00:00:00 2001 From: Isaac Beh Date: Thu, 7 Mar 2024 22:33:48 +1000 Subject: [PATCH 1/3] Fixed various typing issues --- pyproject.toml | 3 --- uqcsbot/error_handler.py | 4 +++- uqcsbot/uptime.py | 2 +- uqcsbot/working_on.py | 4 ++-- 4 files changed, 6 insertions(+), 7 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index b6c2175a..f9548578 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -43,15 +43,12 @@ build-backend = "poetry.core.masonry.api" strict = ["**"] exclude = [ "**/bot.py", - "**/error_handler.py", "**/events.py", "**/gaming.py", "**/member_counter.py", "**/remindme.py", "**/snailrace.py", "**/starboard.py", - "**/uptime.py", - "**/working_on.py", "**/utils/snailrace_utils.py", ] diff --git a/uqcsbot/error_handler.py b/uqcsbot/error_handler.py index 98a55bc2..e6a1ec07 100644 --- a/uqcsbot/error_handler.py +++ b/uqcsbot/error_handler.py @@ -1,6 +1,8 @@ from discord.ext import commands from discord.ext.commands.errors import MissingRequiredArgument import logging +from typing import Any +from uqcsbot.bot import UQCSBot """ TODO: this is bundled with advent.py and should be removed. @@ -9,7 +11,7 @@ class ErrorHandler(commands.Cog): @commands.Cog.listener() - async def on_command_error(self, ctx: commands.Context, err): + async def on_command_error(self, ctx: commands.Context[UQCSBot], err: Any): if isinstance(err, MissingRequiredArgument): await ctx.send( "Missing required argument. For further information refer to `!help`" diff --git a/uqcsbot/uptime.py b/uqcsbot/uptime.py index ad38d7c5..f1caaa2a 100644 --- a/uqcsbot/uptime.py +++ b/uqcsbot/uptime.py @@ -22,7 +22,7 @@ async def on_ready(self): self.bot.uqcs_server.channels, name=self.CHANNEL_NAME ) - if channel is not None: + if isinstance(channel, discord.TextChannel): if random.randint(1, 100) == 1: await channel.send("Oopsie, I webooted uwu >_<") else: diff --git a/uqcsbot/working_on.py b/uqcsbot/working_on.py index e3af632c..8ebfea12 100644 --- a/uqcsbot/working_on.py +++ b/uqcsbot/working_on.py @@ -19,7 +19,7 @@ def __init__(self, bot: UQCSBot): async def workingon(self): """5pm ping for 2 lucky server members to share what they have been working on.""" members = list(self.bot.get_all_members()) - message = [] + message: list[str] = [] while len(message) < 2: chosen = choice(members) @@ -33,7 +33,7 @@ async def workingon(self): self.bot.uqcs_server.channels, name=GENERAL_CHANNEL ) - if general_channel is not None: + if isinstance(general_channel, discord.TextChannel): await general_channel.send( "\n".join(message), allowed_mentions=discord.AllowedMentions( From 49eb5eb4e6188a1d708beb353f759e250cc5c3f9 Mon Sep 17 00:00:00 2001 From: Isaac Beh Date: Thu, 7 Mar 2024 22:37:09 +1000 Subject: [PATCH 2/3] Fixed stub issue for error_handler --- uqcsbot/error_handler.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/uqcsbot/error_handler.py b/uqcsbot/error_handler.py index e6a1ec07..de605876 100644 --- a/uqcsbot/error_handler.py +++ b/uqcsbot/error_handler.py @@ -1,5 +1,4 @@ from discord.ext import commands -from discord.ext.commands.errors import MissingRequiredArgument import logging from typing import Any from uqcsbot.bot import UQCSBot @@ -12,7 +11,7 @@ class ErrorHandler(commands.Cog): @commands.Cog.listener() async def on_command_error(self, ctx: commands.Context[UQCSBot], err: Any): - if isinstance(err, MissingRequiredArgument): + if isinstance(err, commands.errors.MissingRequiredArgument): await ctx.send( "Missing required argument. For further information refer to `!help`" ) From 33367e2be6dc6f08dc89a64b3e9adf35fb0f85e4 Mon Sep 17 00:00:00 2001 From: Isaac Beh Date: Thu, 7 Mar 2024 23:20:52 +1000 Subject: [PATCH 3/3] Added typing for member counter --- pyproject.toml | 1 - uqcsbot/member_counter.py | 26 ++++++++++++++++++++++---- 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index f9548578..91963233 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -45,7 +45,6 @@ exclude = [ "**/bot.py", "**/events.py", "**/gaming.py", - "**/member_counter.py", "**/remindme.py", "**/snailrace.py", "**/starboard.py", diff --git a/uqcsbot/member_counter.py b/uqcsbot/member_counter.py index a6cda54d..2e6939f2 100644 --- a/uqcsbot/member_counter.py +++ b/uqcsbot/member_counter.py @@ -7,13 +7,15 @@ from discord import app_commands from discord.ext import commands +from uqcsbot.bot import UQCSBot + class MemberCounter(commands.Cog): MEMBER_COUNT_PREFIX = "Member Count: " RATE_LIMIT = timedelta(minutes=5) NEW_MEMBER_TIME = timedelta(days=7) - def __init__(self, bot: commands.Bot): + def __init__(self, bot: UQCSBot): self.bot = bot self.last_rename_time = datetime.now() self.waiting_for_rename = False @@ -43,7 +45,13 @@ async def on_ready(self): ) return + if self.bot.user is None: + logging.warning("Could not find the bot's own id.") + return bot_member = self.bot.uqcs_server.get_member(self.bot.user.id) + if bot_member is None: + logging.warning("Could not find the bot's user.") + return permissions = self.member_count_channel.permissions_for(bot_member) if not permissions.manage_channels: logging.warning( @@ -55,17 +63,27 @@ async def on_ready(self): @app_commands.command(name="membercount") async def member_count(self, interaction: discord.Interaction, force: bool = False): """Display the number of members""" + if interaction.guild is None: + logging.warning( + "Could not update member count as could not access members." + ) + return new_members = [ member for member in interaction.guild.members - if member.joined_at + if member.joined_at is not None + and member.joined_at > datetime.now(tz=ZoneInfo("Australia/Brisbane")) - self.NEW_MEMBER_TIME ] await interaction.response.send_message( f"There are currently {interaction.guild.member_count} members in the UQ Computing Society discord server, with {len(new_members)} joining in the last 7 days." ) - if interaction.user.guild_permissions.manage_guild and force: + if ( + isinstance(interaction.user, discord.Member) + and interaction.user.guild_permissions.manage_guild + and force + ): # this is dodgy, but the alternative is to restart the bot # if it gets caught in a loop of waiting for a broken rename self.waiting_for_rename = False @@ -107,5 +125,5 @@ async def _update_member_count_channel_name(self): self.waiting_for_rename = False -async def setup(bot: commands.Bot): +async def setup(bot: UQCSBot): await bot.add_cog(MemberCounter(bot))