mirror of
https://github.com/Cog-Creators/Red-DiscordBot.git
synced 2025-11-06 03:08:55 -05:00
* Readd work due to redoing branch * [modlog] Move to core and start work on separating it from cogs * More work on modlog separation * [Core] Finish logic for modlog, do docstrings, async getters * [Core] Add stuff to dunder all * [Docs] Add mod log docs * [Core] Move away from dunder str for Case class * [Docs] don't need to doc special members in modlog docs * More on mod log to implement commands * More work on Mod * [Mod] compatibility with async getters * [Tests] start tests for mod * [Tests] attempted fix * [Tests] mod tests passing now! * [ModLog] update for i18n * modlog.pot -> messages.pot * [Mod] i18n * fix getting admin/mod roles * Fix doc building * [Mod/Modlog] redo imports * [Tests] fix imports in mod tests * [Mod] fix logger problem * [Mod] cleanup errors * A couple of bug fixes Async getters, some old `config.set` syntax * Filter ignores private channels * Fix softban Was still relying on default channels * Actually ignore private channels * Add check for ignored channels * Fix logic for ignore check * Send confirm messages before making case * Pass in guild when setting modlog * Thanks autocomplete * Maintain all data for case * Properly ignore softbans in events * [Mod] bugfixes * [Mod] more changes * [ModLog] timestamp change * [Mod] split filter and cleanup to their own cogs + regen messages.pot * [Cleanup] change logic * [Cleanup] increase limit for channel.history * [Mod] await getter in modset banmentionspam * [Mod] attempt duplicate modlog message fix * [Mod] get_user -> get_user_info * [Modlog] change reason command so the case author can edit their cases (#806) * [Modlog] make reason command guild only * [Modlog] clarify the reason command's help * [Mod] package path changes + numpy style docstrings for modlog * [Mod] change ban and unban events to need view audit log perms to find/create a case * [Modlog] refactoring * [Filter] add autoban feature * [Mod] update case types + event changes * [Mod/Modlog] fix tests, fix permissions things * [Docs] fix up modlog docs * Regenerate messages.pot
155 lines
5.8 KiB
Python
155 lines
5.8 KiB
Python
import discord
|
|
from discord.ext import commands
|
|
|
|
from redbot.core import checks, modlog
|
|
from redbot.core.bot import Red
|
|
from redbot.core.i18n import CogI18n
|
|
from redbot.core.utils.chat_formatting import box
|
|
|
|
_ = CogI18n('ModLog', __file__)
|
|
|
|
|
|
class ModLog:
|
|
"""Log for mod actions"""
|
|
|
|
def __init__(self, bot: Red):
|
|
self.bot = bot
|
|
|
|
@commands.group()
|
|
@checks.guildowner_or_permissions(administrator=True)
|
|
async def modlogset(self, ctx: commands.Context):
|
|
"""Settings for the mod log"""
|
|
if ctx.invoked_subcommand is None:
|
|
await self.bot.send_cmd_help(ctx)
|
|
|
|
@modlogset.command()
|
|
@commands.guild_only()
|
|
async def modlog(self, ctx: commands.Context, channel: discord.TextChannel = None):
|
|
"""Sets a channel as mod log
|
|
|
|
Leaving the channel parameter empty will deactivate it"""
|
|
guild = ctx.guild
|
|
if channel:
|
|
if channel.permissions_for(guild.me).send_messages:
|
|
await modlog.set_modlog_channel(guild, channel)
|
|
await ctx.send(
|
|
_("Mod events will be sent to {}").format(
|
|
channel.mention
|
|
)
|
|
)
|
|
else:
|
|
await ctx.send(
|
|
_("I do not have permissions to "
|
|
"send messages in {}!").format(channel.mention)
|
|
)
|
|
else:
|
|
try:
|
|
await modlog.get_modlog_channel(guild)
|
|
except RuntimeError:
|
|
await self.bot.send_cmd_help(ctx)
|
|
else:
|
|
await modlog.set_modlog_channel(guild, None)
|
|
await ctx.send(_("Mod log deactivated."))
|
|
|
|
@modlogset.command(name='cases')
|
|
@commands.guild_only()
|
|
async def set_cases(self, ctx: commands.Context, action: str = None):
|
|
"""Enables or disables case creation for each type of mod action"""
|
|
guild = ctx.guild
|
|
|
|
if action is None: # No args given
|
|
casetypes = await modlog.get_all_casetypes()
|
|
await self.bot.send_cmd_help(ctx)
|
|
title = _("Current settings:")
|
|
msg = ""
|
|
for ct in casetypes:
|
|
enabled = await ct.is_enabled()
|
|
value = 'enabled' if enabled else 'disabled'
|
|
msg += '%s : %s\n' % (ct.name, value)
|
|
|
|
msg = title + "\n" + box(msg)
|
|
await ctx.send(msg)
|
|
return
|
|
casetype = await modlog.get_casetype(action, guild)
|
|
if not casetype:
|
|
await ctx.send(_("That action is not registered"))
|
|
else:
|
|
|
|
enabled = await casetype.is_enabled()
|
|
await casetype.set_enabled(True if not enabled else False)
|
|
|
|
msg = (
|
|
_('Case creation for {} actions is now {}.').format(
|
|
action, 'enabled' if not enabled else 'disabled'
|
|
)
|
|
)
|
|
await ctx.send(msg)
|
|
|
|
@modlogset.command()
|
|
@commands.guild_only()
|
|
async def resetcases(self, ctx: commands.Context):
|
|
"""Resets modlog's cases"""
|
|
guild = ctx.guild
|
|
await modlog.reset_cases(guild)
|
|
await ctx.send(_("Cases have been reset."))
|
|
|
|
@commands.command()
|
|
@commands.guild_only()
|
|
async def case(self, ctx: commands.Context, number: int):
|
|
"""Shows the specified case"""
|
|
try:
|
|
case = await modlog.get_case(number, ctx.guild, self.bot)
|
|
except RuntimeError:
|
|
await ctx.send(_("That case does not exist for that guild"))
|
|
return
|
|
else:
|
|
await ctx.send(embed=await case.get_case_msg_content())
|
|
|
|
@commands.command()
|
|
@commands.guild_only()
|
|
async def reason(self, ctx: commands.Context, case: int, *, reason: str = ""):
|
|
"""Lets you specify a reason for mod-log's cases
|
|
Please note that you can only edit cases you are
|
|
the owner of unless you are a mod/admin or the guild owner"""
|
|
author = ctx.author
|
|
guild = ctx.guild
|
|
if not reason:
|
|
await self.bot.send_cmd_help(ctx)
|
|
return
|
|
try:
|
|
case_before = await modlog.get_case(case, guild, self.bot)
|
|
except RuntimeError:
|
|
await ctx.send(_("That case does not exist!"))
|
|
return
|
|
else:
|
|
if case_before.moderator is None:
|
|
# No mod set, so attempt to find out if the author
|
|
# triggered the case creation with an action
|
|
bot_perms = guild.me.guild_permissions
|
|
if bot_perms.view_audit_log:
|
|
case_type = await modlog.get_casetype(case_before.action_type, guild)
|
|
audit_type = getattr(discord.AuditLogAction, case_type.audit_type)
|
|
if audit_type:
|
|
audit_case = None
|
|
async for entry in guild.audit_logs(action=audit_type):
|
|
if entry.target.id == case_before.user.id and \
|
|
entry.user.id == case_before.moderator.id:
|
|
audit_case = entry
|
|
break
|
|
if audit_case:
|
|
case_before.moderator = audit_case.user
|
|
is_guild_owner = author == guild.owner
|
|
is_case_author = author == case_before.moderator
|
|
author_is_mod = await ctx.bot.is_mod(author)
|
|
if not (is_guild_owner or is_case_author or author_is_mod):
|
|
await ctx.send(_("You are not authorized to modify that case!"))
|
|
return
|
|
to_modify = {
|
|
"reason": reason,
|
|
}
|
|
if case_before.moderator != author:
|
|
to_modify["amended_by"] = author
|
|
to_modify["modified_at"] = ctx.message.created_at.timestamp()
|
|
await case_before.edit(to_modify)
|
|
await ctx.send(_("Reason has been updated."))
|