mirror of
https://github.com/RGBCube/minearchy-bot
synced 2025-07-27 08:57:46 +00:00
Move snipe to moderation
This commit is contained in:
parent
5ab80712d0
commit
763f2551a9
2 changed files with 70 additions and 67 deletions
|
@ -1,6 +1,5 @@
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
from collections import defaultdict as DefaultDict, deque as Deque
|
|
||||||
from datetime import timedelta as TimeDelta
|
from datetime import timedelta as TimeDelta
|
||||||
from inspect import cleandoc as strip
|
from inspect import cleandoc as strip
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
|
@ -8,8 +7,7 @@ from platform import python_version
|
||||||
from time import monotonic as get_monotonic, time as get_time
|
from time import monotonic as get_monotonic, time as get_time
|
||||||
from typing import TYPE_CHECKING
|
from typing import TYPE_CHECKING
|
||||||
|
|
||||||
from discord import CategoryChannel, Color, Embed, File, TextChannel
|
from discord import CategoryChannel, File
|
||||||
from discord.ext import commands
|
|
||||||
from discord.ext.commands import Cog, command
|
from discord.ext.commands import Cog, command
|
||||||
from discord.utils import escape_markdown
|
from discord.utils import escape_markdown
|
||||||
|
|
||||||
|
@ -30,7 +28,6 @@ class Miscellaneous(
|
||||||
def __init__(self, bot: MinearchyBot) -> None:
|
def __init__(self, bot: MinearchyBot) -> None:
|
||||||
self.bot = bot
|
self.bot = bot
|
||||||
self.bot.help_command.cog = self
|
self.bot.help_command.cog = self
|
||||||
self.sniped = DefaultDict(Deque)
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
def cog_unload(self) -> None:
|
def cog_unload(self) -> None:
|
||||||
|
@ -149,68 +146,6 @@ class Miscellaneous(
|
||||||
await message.author.edit(nick=message.author.display_name[5:])
|
await message.author.edit(nick=message.author.display_name[5:])
|
||||||
await message.channel.send(f"Welcome back {message.author.mention}! I've unset your AFK status.")
|
await message.channel.send(f"Welcome back {message.author.mention}! I've unset your AFK status.")
|
||||||
|
|
||||||
@command(
|
|
||||||
brief="Sends the latest deleted messages.",
|
|
||||||
help=(
|
|
||||||
"Sends the last 5 deleted messages in a specified channel.\nIf the channel"
|
|
||||||
" isn't specified, it uses the current channel."
|
|
||||||
),
|
|
||||||
)
|
|
||||||
@commands.has_permissions(manage_messages=True) # needs to be able to delete messages to run the command
|
|
||||||
async def snipe(self, ctx: Context, channel: TextChannel | None = None) -> None:
|
|
||||||
if channel is None:
|
|
||||||
channel = ctx.channel
|
|
||||||
|
|
||||||
logs = self.sniped[channel.id]
|
|
||||||
|
|
||||||
if not logs:
|
|
||||||
await ctx.reply(
|
|
||||||
"There are no messages to be sniped in"
|
|
||||||
f" {'this channel.' if channel.id == ctx.channel.id else channel.mention}"
|
|
||||||
)
|
|
||||||
return
|
|
||||||
|
|
||||||
embed = Embed(
|
|
||||||
title=(
|
|
||||||
"Showing last 5 deleted messages for"
|
|
||||||
f" {'the current channel' if ctx.channel.id == channel.id else channel}"
|
|
||||||
),
|
|
||||||
description="The lower the number is, the more recent it got deleted.",
|
|
||||||
color=Color.random(),
|
|
||||||
)
|
|
||||||
|
|
||||||
zwsp = "\uFEFF"
|
|
||||||
|
|
||||||
for i, log in reversed(list(enumerate(logs))):
|
|
||||||
message, ts = log
|
|
||||||
|
|
||||||
embed.add_field(
|
|
||||||
name=str(i) + ("" if i else " (latest)"),
|
|
||||||
value=strip(
|
|
||||||
f"""
|
|
||||||
Author: {message.author.mention} (ID: {message.author.id}, Plain: {escape_markdown(str(message.author))})
|
|
||||||
Deleted at: <t:{ts}:F> (Relative: <t:{ts}:R>)
|
|
||||||
Content:
|
|
||||||
```
|
|
||||||
{message.content.replace('`', f'{zwsp}`{zwsp}')}
|
|
||||||
```
|
|
||||||
"""
|
|
||||||
),
|
|
||||||
inline=False,
|
|
||||||
)
|
|
||||||
|
|
||||||
await ctx.reply(embed=embed)
|
|
||||||
|
|
||||||
@Cog.listener()
|
|
||||||
async def on_message_delete(self, message: Message) -> None:
|
|
||||||
if not message.guild:
|
|
||||||
return
|
|
||||||
|
|
||||||
self.sniped[message.channel.id].appendleft((message, int(get_time())))
|
|
||||||
|
|
||||||
while len(self.sniped[message.channel.id]) > 5:
|
|
||||||
self.sniped[message.channel.id].pop()
|
|
||||||
|
|
||||||
|
|
||||||
async def setup(bot: MinearchyBot) -> None:
|
async def setup(bot: MinearchyBot) -> None:
|
||||||
await bot.add_cog(Miscellaneous(bot))
|
await bot.add_cog(Miscellaneous(bot))
|
||||||
|
|
|
@ -1,13 +1,18 @@
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from collections import defaultdict as DefaultDict, deque as Deque
|
||||||
from datetime import timedelta as TimeDelta
|
from datetime import timedelta as TimeDelta
|
||||||
|
from inspect import cleandoc as strip
|
||||||
|
from time import time as get_time
|
||||||
from typing import TYPE_CHECKING
|
from typing import TYPE_CHECKING
|
||||||
|
|
||||||
|
from discord import Color, Embed, TextChannel
|
||||||
from discord.ext import commands
|
from discord.ext import commands
|
||||||
from discord.ext.commands import Cog, command
|
from discord.ext.commands import Cog, command
|
||||||
|
from discord.utils import escape_markdown
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
from discord import Member
|
from discord import Member, Message
|
||||||
from discord.ext.commands import Context
|
from discord.ext.commands import Context
|
||||||
|
|
||||||
from .. import MinearchyBot
|
from .. import MinearchyBot
|
||||||
|
@ -22,6 +27,7 @@ class Moderation(Cog):
|
||||||
"m": "minutes",
|
"m": "minutes",
|
||||||
"s": "seconds",
|
"s": "seconds",
|
||||||
}
|
}
|
||||||
|
self.sniped = DefaultDict(Deque)
|
||||||
|
|
||||||
@command(
|
@command(
|
||||||
aliases=("mute",),
|
aliases=("mute",),
|
||||||
|
@ -50,6 +56,68 @@ class Moderation(Cog):
|
||||||
|
|
||||||
await ctx.reply(f"Timed out {member.mention} for {time} {clean_time_name}.")
|
await ctx.reply(f"Timed out {member.mention} for {time} {clean_time_name}.")
|
||||||
|
|
||||||
|
@command(
|
||||||
|
brief="Sends the latest deleted messages.",
|
||||||
|
help=(
|
||||||
|
"Sends the last 5 deleted messages in a specified channel.\nIf the channel"
|
||||||
|
" isn't specified, it uses the current channel."
|
||||||
|
),
|
||||||
|
)
|
||||||
|
@commands.has_permissions(manage_messages=True) # needs to be able to delete messages to run the command
|
||||||
|
async def snipe(self, ctx: Context, channel: TextChannel | None = None) -> None:
|
||||||
|
if channel is None:
|
||||||
|
channel = ctx.channel
|
||||||
|
|
||||||
|
logs = self.sniped[channel.id]
|
||||||
|
|
||||||
|
if not logs:
|
||||||
|
await ctx.reply(
|
||||||
|
"There are no messages to be sniped in"
|
||||||
|
f" {'this channel.' if channel.id == ctx.channel.id else channel.mention}"
|
||||||
|
)
|
||||||
|
return
|
||||||
|
|
||||||
|
embed = Embed(
|
||||||
|
title=(
|
||||||
|
"Showing last 5 deleted messages for"
|
||||||
|
f" {'the current channel' if ctx.channel.id == channel.id else channel}"
|
||||||
|
),
|
||||||
|
description="The lower the number is, the more recent it got deleted.",
|
||||||
|
color=Color.random(),
|
||||||
|
)
|
||||||
|
|
||||||
|
zwsp = "\uFEFF"
|
||||||
|
|
||||||
|
for i, log in reversed(list(enumerate(logs))):
|
||||||
|
message, ts = log
|
||||||
|
|
||||||
|
embed.add_field(
|
||||||
|
name=str(i) + ("" if i else " (latest)"),
|
||||||
|
value=strip(
|
||||||
|
f"""
|
||||||
|
Author: {message.author.mention} (ID: {message.author.id}, Plain: {escape_markdown(str(message.author))})
|
||||||
|
Deleted at: <t:{ts}:F> (Relative: <t:{ts}:R>)
|
||||||
|
Content:
|
||||||
|
```
|
||||||
|
{message.content.replace('`', f'{zwsp}`{zwsp}')}
|
||||||
|
```
|
||||||
|
"""
|
||||||
|
),
|
||||||
|
inline=False,
|
||||||
|
)
|
||||||
|
|
||||||
|
await ctx.reply(embed=embed)
|
||||||
|
|
||||||
|
@Cog.listener()
|
||||||
|
async def on_message_delete(self, message: Message) -> None:
|
||||||
|
if not message.guild:
|
||||||
|
return
|
||||||
|
|
||||||
|
self.sniped[message.channel.id].appendleft((message, int(get_time())))
|
||||||
|
|
||||||
|
while len(self.sniped[message.channel.id]) > 5:
|
||||||
|
self.sniped[message.channel.id].pop()
|
||||||
|
|
||||||
|
|
||||||
async def setup(bot: MinearchyBot) -> None:
|
async def setup(bot: MinearchyBot) -> None:
|
||||||
await bot.add_cog(Moderation(bot))
|
await bot.add_cog(Moderation(bot))
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue