WIP: Refactor Aurora (3.0.0) #29
1 changed files with 54 additions and 51 deletions
105
aurora/aurora.py
105
aurora/aurora.py
|
@ -113,7 +113,7 @@ class Aurora(commands.Cog):
|
||||||
self.handle_expiry.cancel()
|
self.handle_expiry.cancel()
|
||||||
|
|
||||||
@commands.Cog.listener("on_guild_join")
|
@commands.Cog.listener("on_guild_join")
|
||||||
async def db_generate_guild_join(self, guild: discord.Guild):
|
async def db_generate_on_guild_join(self, guild: discord.Guild):
|
||||||
"""This method prepares the database schema whenever the bot joins a guild."""
|
"""This method prepares the database schema whenever the bot joins a guild."""
|
||||||
if not await self.bot.cog_disabled_in_guild(self, guild):
|
if not await self.bot.cog_disabled_in_guild(self, guild):
|
||||||
try:
|
try:
|
||||||
|
@ -135,58 +135,61 @@ class Aurora(commands.Cog):
|
||||||
@commands.Cog.listener("on_audit_log_entry_create")
|
@commands.Cog.listener("on_audit_log_entry_create")
|
||||||
async def autologger(self, entry: discord.AuditLogEntry):
|
async def autologger(self, entry: discord.AuditLogEntry):
|
||||||
"""This method automatically logs moderations done by users manually ("right clicks")."""
|
"""This method automatically logs moderations done by users manually ("right clicks")."""
|
||||||
if not await self.bot.cog_disabled_in_guild(self, entry.guild):
|
try:
|
||||||
if await config.guild(entry.guild).ignore_other_bots() is True:
|
if not await self.bot.cog_disabled_in_guild(self, entry.guild):
|
||||||
if entry.user.bot or entry.target.bot:
|
if await config.guild(entry.guild).ignore_other_bots() is True:
|
||||||
return
|
if entry.user.bot or entry.target.bot:
|
||||||
else:
|
return
|
||||||
if entry.user.id == self.bot.user.id:
|
|
||||||
return
|
|
||||||
|
|
||||||
duration = None
|
|
||||||
|
|
||||||
if entry.reason:
|
|
||||||
reason = entry.reason + " (This action was performed without the bot.)"
|
|
||||||
|
|
||||||
else:
|
|
||||||
reason = "This action was performed without the bot."
|
|
||||||
|
|
||||||
if entry.action == discord.AuditLogAction.kick:
|
|
||||||
moderation_type = "KICK"
|
|
||||||
|
|
||||||
elif entry.action == discord.AuditLogAction.ban:
|
|
||||||
moderation_type = "BAN"
|
|
||||||
|
|
||||||
elif entry.action == discord.AuditLogAction.unban:
|
|
||||||
moderation_type = "UNBAN"
|
|
||||||
|
|
||||||
elif entry.action == discord.AuditLogAction.member_update:
|
|
||||||
if entry.after.timed_out_until is not None:
|
|
||||||
timed_out_until_aware = entry.after.timed_out_until.replace(
|
|
||||||
tzinfo=timezone.utc
|
|
||||||
)
|
|
||||||
duration_datetime = timed_out_until_aware - datetime.now(
|
|
||||||
tz=timezone.utc
|
|
||||||
)
|
|
||||||
minutes = round(duration_datetime.total_seconds() / 60)
|
|
||||||
duration = timedelta(minutes=minutes)
|
|
||||||
moderation_type = "MUTE"
|
|
||||||
else:
|
else:
|
||||||
moderation_type = "UNMUTE"
|
if entry.user.id == self.bot.user.id:
|
||||||
else:
|
return
|
||||||
return
|
|
||||||
|
|
||||||
await Moderation.log(
|
duration = None
|
||||||
self.bot,
|
|
||||||
entry.guild.id,
|
if entry.reason:
|
||||||
entry.user.id,
|
reason = entry.reason + " (This action was performed without the bot.)"
|
||||||
moderation_type,
|
|
||||||
"USER",
|
else:
|
||||||
entry.target.id,
|
reason = "This action was performed without the bot."
|
||||||
None,
|
|
||||||
duration,
|
if entry.action == discord.AuditLogAction.kick:
|
||||||
reason,
|
moderation_type = "KICK"
|
||||||
)
|
|
||||||
|
elif entry.action == discord.AuditLogAction.ban:
|
||||||
|
moderation_type = "BAN"
|
||||||
|
|
||||||
|
elif entry.action == discord.AuditLogAction.unban:
|
||||||
|
moderation_type = "UNBAN"
|
||||||
|
|
||||||
|
elif entry.action == discord.AuditLogAction.member_update:
|
||||||
|
if entry.after.timed_out_until is not None:
|
||||||
|
timed_out_until_aware = entry.after.timed_out_until.replace(
|
||||||
|
tzinfo=timezone.utc
|
||||||
|
)
|
||||||
|
duration_datetime = timed_out_until_aware - datetime.now(
|
||||||
|
tz=timezone.utc
|
||||||
|
)
|
||||||
|
minutes = round(duration_datetime.total_seconds() / 60)
|
||||||
|
duration = timedelta(minutes=minutes)
|
||||||
|
moderation_type = "MUTE"
|
||||||
|
else:
|
||||||
|
moderation_type = "UNMUTE"
|
||||||
|
else:
|
||||||
|
return
|
||||||
|
|
||||||
|
await Moderation.log(
|
||||||
|
self.bot,
|
||||||
|
entry.guild.id,
|
||||||
|
entry.user.id,
|
||||||
|
moderation_type,
|
||||||
|
"USER",
|
||||||
|
entry.target.id,
|
||||||
|
None,
|
||||||
|
duration,
|
||||||
|
reason,
|
||||||
|
)
|
||||||
|
except AttributeError:
|
||||||
|
return
|
||||||
|
|
||||||
#######################################################################################################################
|
#######################################################################################################################
|
||||||
### COMMANDS
|
### COMMANDS
|
||||||
|
|
Loading…
Reference in a new issue