Change structure of case viewing, add actions view

This commit is contained in:
Zeva Rose 2022-05-03 15:27:02 -06:00
parent 7968dd7780
commit 3ea435aaa3

View file

@ -1,5 +1,5 @@
"""JARVIS Moderation Case management.""" """JARVIS Moderation Case management."""
from typing import TYPE_CHECKING, Optional from typing import TYPE_CHECKING, List, Optional
from jarvis_core.db import q from jarvis_core.db import q
from jarvis_core.db.models import Modlog, actions from jarvis_core.db.models import Modlog, actions
@ -34,9 +34,9 @@ ACTIONS_LOOKUP = {
class CaseCog(Cog): class CaseCog(Cog):
"""JARVIS CaseCog.""" """JARVIS CaseCog."""
async def get_embed(self, mod_case: Modlog, guild: "Guild") -> Embed: async def get_summary_embed(self, mod_case: Modlog, guild: "Guild") -> Embed:
""" """
Get Moderation case embed. Get Moderation case summary embed.
Args: Args:
mod_case: Moderation case mod_case: Moderation case
@ -59,10 +59,10 @@ class CaseCog(Cog):
parent_action = await ACTIONS_LOOKUP[action.action_type].find_one(q(id=action.parent)) parent_action = await ACTIONS_LOOKUP[action.action_type].find_one(q(id=action.parent))
if not parent_action: if not parent_action:
action.orphaned = True action.orphaned = True
action_table.add_row(action.action_type.title(), "N/A", "N/A") action_table.add_row(action.action_type.title(), "[N/A]", "[N/A]")
else: else:
admin = await self.bot.fetch_user(parent_action.admin) admin = await self.bot.fetch_user(parent_action.admin)
admin_text = "Deleted User" admin_text = "[N/A]"
if admin: if admin:
admin_text = f"{admin.username}#{admin.discriminator}" admin_text = f"{admin.username}#{admin.discriminator}"
action_table.add_row(action.action_type.title(), admin_text, parent_action.reason) action_table.add_row(action.action_type.title(), admin_text, parent_action.reason)
@ -81,7 +81,7 @@ class CaseCog(Cog):
notes = sorted(mod_case.notes, key=lambda x: x.created_at) notes = sorted(mod_case.notes, key=lambda x: x.created_at)
for idx, note in enumerate(notes): for idx, note in enumerate(notes):
admin = await self.bot.fetch_user(note.admin) admin = await self.bot.fetch_user(note.admin)
admin_text = "N/A" admin_text = "[N/A]"
if admin: if admin:
admin_text = f"{admin.username}#{admin.discriminator}" admin_text = f"{admin.username}#{admin.discriminator}"
note_table.add_row(admin_text, note.content) note_table.add_row(admin_text, note.content)
@ -99,8 +99,8 @@ class CaseCog(Cog):
status = "Open" if mod_case.open else "Closed" status = "Open" if mod_case.open else "Closed"
user = await self.bot.fetch_user(mod_case.user) user = await self.bot.fetch_user(mod_case.user)
username = "Deleted User" username = "[N/A]"
user_text = "Deleted User" user_text = "[N/A]"
if user: if user:
username = f"{user.username}#{user.discriminator}" username = f"{user.username}#{user.discriminator}"
user_text = user.mention user_text = user.mention
@ -134,6 +134,53 @@ class CaseCog(Cog):
await mod_case.commit() await mod_case.commit()
return embed return embed
async def get_action_embeds(self, mod_case: Modlog, guild: "Guild") -> List[Embed]:
"""
Get Moderation case action embeds.
Args:
mod_case: Moderation case
guild: Originating guild
"""
embeds = []
user = await self.bot.fetch_user(mod_case.user)
username = "[N/A]"
user_mention = "[N/A]"
avatar_url = None
if user:
username = f"{user.username}#{user.discriminator}"
avatar_url = user.avatar.url
user_mention = user.mention
for action in mod_case.actions:
if action.orphaned:
continue
parent_action = await ACTIONS_LOOKUP[action.action_type].find_one(q(id=action.parent))
if not parent_action:
action.orphaned = True
continue
admin = await self.bot.fetch_user(parent_action.admin)
admin_text = "[N/A]"
if admin:
admin_text = admin.mention
fields = (
EmbedField(name="Admin", value=admin_text),
EmbedField(name="Reason", value=parent_action.reason),
)
embed = build_embed(
title="Moderation Case Action",
description=f"{user_mention} was warned by {admin_text}",
fields=fields,
timestamp=parent_action.created_at,
)
embed.set_author(name=username, icon_url=avatar_url)
embeds.append(embed)
await mod_case.commit()
return embeds
cases = SlashCommand(name="cases", description="Manage moderation cases") cases = SlashCommand(name="cases", description="Manage moderation cases")
@cases.subcommand(sub_cmd_name="list", sub_cmd_description="List moderation cases") @cases.subcommand(sub_cmd_name="list", sub_cmd_description="List moderation cases")
@ -164,24 +211,38 @@ class CaseCog(Cog):
await ctx.send("No cases to view", ephemeral=True) await ctx.send("No cases to view", ephemeral=True)
return return
pages = [await self.get_embed(c, ctx.guild) for c in cases] pages = [await self.get_summary_embed(c, ctx.guild) for c in cases]
paginator = Paginator.create_from_embeds(self.bot, *pages, timeout=300) paginator = Paginator.create_from_embeds(self.bot, *pages, timeout=300)
await paginator.send(ctx) await paginator.send(ctx)
case = SlashCommand(name="case", description="Manage a moderation case") case = SlashCommand(name="case", description="Manage a moderation case")
show = case.group(name="show", description="Show information about a specific case")
@case.subcommand(sub_cmd_name="show", sub_cmd_description="Show a specific case") @show.subcommand(sub_cmd_name="summary", sub_cmd_description="Summarize a specific case")
@slash_option(name="cid", description="Case ID", opt_type=OptionTypes.STRING, required=True) @slash_option(name="cid", description="Case ID", opt_type=OptionTypes.STRING, required=True)
@check(admin_or_permissions(Permissions.BAN_MEMBERS)) @check(admin_or_permissions(Permissions.BAN_MEMBERS))
async def _case_show(self, ctx: InteractionContext, cid: str) -> None: async def _case_show_summary(self, ctx: InteractionContext, cid: str) -> None:
case = await Modlog.find_one(q(guild=ctx.guild.id, nanoid=cid)) case = await Modlog.find_one(q(guild=ctx.guild.id, nanoid=cid))
if not case: if not case:
await ctx.send(f"Could not find case with ID {cid}", ephemeral=True) await ctx.send(f"Could not find case with ID {cid}", ephemeral=True)
return return
embed = await self.get_embed(case, ctx.guild) embed = await self.get_summary_embed(case, ctx.guild)
await ctx.send(embed=embed) await ctx.send(embed=embed)
@show.subcommand(sub_cmd_name="actions", description="Get case actions")
@slash_option(name="cid", description="Case ID", opt_type=OptionTypes.STRING, required=True)
@check(admin_or_permissions(Permissions.BAN_MEMBERS))
async def _case_show_actions(self, ctx: InteractionContext, cid: str) -> None:
case = await Modlog.find_one(q(guild=ctx.guild.id, nanoid=cid))
if not case:
await ctx.send(f"Could not find case with ID {cid}", ephemeral=True)
return
pages = await self.get_action_embeds(case, ctx.guild)
paginator = Paginator.create_from_embeds(self.bot, *pages, timeout=300)
await paginator.send(ctx)
@case.subcommand(sub_cmd_name="close", sub_cmd_description="Show a specific case") @case.subcommand(sub_cmd_name="close", sub_cmd_description="Show a specific case")
@slash_option(name="cid", description="Case ID", opt_type=OptionTypes.STRING, required=True) @slash_option(name="cid", description="Case ID", opt_type=OptionTypes.STRING, required=True)
@check(admin_or_permissions(Permissions.BAN_MEMBERS)) @check(admin_or_permissions(Permissions.BAN_MEMBERS))
@ -194,5 +255,5 @@ class CaseCog(Cog):
case.open = False case.open = False
await case.commit() await case.commit()
embed = await self.get_embed(case, ctx.guild) embed = await self.get_summary_embed(case, ctx.guild)
await ctx.send(embed=embed) await ctx.send(embed=embed)