2018-12-28 00:36:18 +03:00
|
|
|
import discord
|
|
|
|
import config
|
2018-12-29 22:07:58 +03:00
|
|
|
from datetime import datetime
|
2018-12-28 00:36:18 +03:00
|
|
|
from discord.ext import commands
|
2019-02-28 23:10:30 +01:00
|
|
|
from discord.ext.commands import Cog
|
2018-12-28 00:36:18 +03:00
|
|
|
from helpers.checks import check_if_staff
|
|
|
|
from helpers.robocronp import add_job
|
|
|
|
from helpers.userlogs import userlog
|
|
|
|
from helpers.restrictions import add_restriction
|
|
|
|
|
|
|
|
|
2019-02-28 23:10:30 +01:00
|
|
|
class ModTimed(Cog):
|
2018-12-28 00:36:18 +03:00
|
|
|
def __init__(self, bot):
|
|
|
|
self.bot = bot
|
|
|
|
|
|
|
|
def check_if_target_is_staff(self, target):
|
|
|
|
return any(r.id in config.staff_role_ids for r in target.roles)
|
|
|
|
|
|
|
|
@commands.guild_only()
|
|
|
|
@commands.bot_has_permissions(ban_members=True)
|
|
|
|
@commands.check(check_if_staff)
|
|
|
|
@commands.command()
|
2020-04-21 01:05:32 +03:00
|
|
|
async def timeban(
|
|
|
|
self, ctx, target: discord.Member, duration: str, *, reason: str = ""
|
|
|
|
):
|
2018-12-29 22:07:58 +03:00
|
|
|
"""Bans a user for a specified amount of time, staff only."""
|
2018-12-28 00:36:18 +03:00
|
|
|
# Hedge-proofing the code
|
|
|
|
if target == ctx.author:
|
|
|
|
return await ctx.send("You can't do mod actions on yourself.")
|
|
|
|
elif self.check_if_target_is_staff(target):
|
2020-05-17 23:44:15 +03:00
|
|
|
return await ctx.send("I can't ban this user as they're a member of staff.")
|
2018-12-28 00:36:18 +03:00
|
|
|
|
2018-12-29 22:07:58 +03:00
|
|
|
expiry_timestamp = self.bot.parse_time(duration)
|
|
|
|
expiry_datetime = datetime.utcfromtimestamp(expiry_timestamp)
|
2020-04-21 01:05:32 +03:00
|
|
|
duration_text = self.bot.get_relative_timestamp(
|
|
|
|
time_to=expiry_datetime, include_to=True, humanized=True
|
|
|
|
)
|
|
|
|
|
|
|
|
userlog(
|
|
|
|
target.id,
|
|
|
|
ctx.author,
|
|
|
|
f"{reason} (Timed, until " f"{duration_text})",
|
|
|
|
"bans",
|
|
|
|
target.name,
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
|
2020-10-01 20:03:41 -04:00
|
|
|
safe_name = await commands.clean_content(escape_markdown=True).convert(
|
|
|
|
ctx, str(target)
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
|
|
|
|
dm_message = f"You were banned from {ctx.guild.name}."
|
|
|
|
if reason:
|
2020-04-21 01:05:32 +03:00
|
|
|
dm_message += f' The given reason is: "{reason}".'
|
2018-12-29 22:07:58 +03:00
|
|
|
dm_message += f"\n\nThis ban will expire {duration_text}."
|
2018-12-28 00:36:18 +03:00
|
|
|
|
|
|
|
try:
|
|
|
|
await target.send(dm_message)
|
|
|
|
except discord.errors.Forbidden:
|
|
|
|
# Prevents ban issues in cases where user blocked bot
|
|
|
|
# or has DMs disabled
|
|
|
|
pass
|
|
|
|
|
2020-04-21 01:05:32 +03:00
|
|
|
await target.ban(
|
|
|
|
reason=f"{ctx.author}, reason: {reason}", delete_message_days=0
|
|
|
|
)
|
|
|
|
chan_message = (
|
|
|
|
f"⛔ **Timed Ban**: {ctx.author.mention} banned "
|
|
|
|
f"{target.mention} for {duration_text} | {safe_name}\n"
|
|
|
|
f"🏷 __User ID__: {target.id}\n"
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
if reason:
|
2020-04-21 01:05:32 +03:00
|
|
|
chan_message += f'✏️ __Reason__: "{reason}"'
|
2018-12-28 00:36:18 +03:00
|
|
|
else:
|
2020-04-21 01:05:32 +03:00
|
|
|
chan_message += (
|
|
|
|
"Please add an explanation below. In the future"
|
|
|
|
", it is recommended to use `.ban <user> [reason]`"
|
|
|
|
" as the reason is automatically sent to the user."
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
|
|
|
|
add_job("unban", target.id, {"guild": ctx.guild.id}, expiry_timestamp)
|
|
|
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
await log_channel.send(chan_message)
|
2020-04-21 01:05:32 +03:00
|
|
|
await ctx.send(f"{safe_name} is now b&. " f"It will expire {duration_text}. 👍")
|
2018-12-28 00:36:18 +03:00
|
|
|
|
|
|
|
@commands.guild_only()
|
|
|
|
@commands.check(check_if_staff)
|
|
|
|
@commands.command()
|
2020-04-21 01:05:32 +03:00
|
|
|
async def timemute(
|
|
|
|
self, ctx, target: discord.Member, duration: str, *, reason: str = ""
|
|
|
|
):
|
2018-12-29 22:07:58 +03:00
|
|
|
"""Mutes a user for a specified amount of time, staff only."""
|
2018-12-28 00:36:18 +03:00
|
|
|
# Hedge-proofing the code
|
|
|
|
if target == ctx.author:
|
|
|
|
return await ctx.send("You can't do mod actions on yourself.")
|
|
|
|
elif self.check_if_target_is_staff(target):
|
2020-04-21 01:05:32 +03:00
|
|
|
return await ctx.send(
|
2020-05-17 23:44:15 +03:00
|
|
|
"I can't mute this user as they're a member of staff."
|
2020-04-21 01:05:32 +03:00
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
|
2018-12-29 22:07:58 +03:00
|
|
|
expiry_timestamp = self.bot.parse_time(duration)
|
|
|
|
expiry_datetime = datetime.utcfromtimestamp(expiry_timestamp)
|
2020-04-21 01:05:32 +03:00
|
|
|
duration_text = self.bot.get_relative_timestamp(
|
|
|
|
time_to=expiry_datetime, include_to=True, humanized=True
|
|
|
|
)
|
|
|
|
|
|
|
|
userlog(
|
|
|
|
target.id,
|
|
|
|
ctx.author,
|
|
|
|
f"{reason} (Timed, until " f"{duration_text})",
|
|
|
|
"mutes",
|
|
|
|
target.name,
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
|
2020-10-01 20:03:41 -04:00
|
|
|
safe_name = await commands.clean_content(escape_markdown=True).convert(
|
|
|
|
ctx, str(target)
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
|
|
|
|
dm_message = f"You were muted!"
|
|
|
|
if reason:
|
2020-04-21 01:05:32 +03:00
|
|
|
dm_message += f' The given reason is: "{reason}".'
|
2018-12-29 22:07:58 +03:00
|
|
|
dm_message += f"\n\nThis mute will expire {duration_text}."
|
2018-12-28 00:36:18 +03:00
|
|
|
|
|
|
|
try:
|
|
|
|
await target.send(dm_message)
|
|
|
|
except discord.errors.Forbidden:
|
|
|
|
# Prevents kick issues in cases where user blocked bot
|
|
|
|
# or has DMs disabled
|
|
|
|
pass
|
|
|
|
|
|
|
|
mute_role = ctx.guild.get_role(config.mute_role)
|
|
|
|
|
|
|
|
await target.add_roles(mute_role, reason=str(ctx.author))
|
|
|
|
|
2020-04-21 01:05:32 +03:00
|
|
|
chan_message = (
|
|
|
|
f"🔇 **Timed Mute**: {ctx.author.mention} muted "
|
|
|
|
f"{target.mention} for {duration_text} | {safe_name}\n"
|
|
|
|
f"🏷 __User ID__: {target.id}\n"
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
if reason:
|
2020-04-21 01:05:32 +03:00
|
|
|
chan_message += f'✏️ __Reason__: "{reason}"'
|
2018-12-28 00:36:18 +03:00
|
|
|
else:
|
2020-04-21 01:05:32 +03:00
|
|
|
chan_message += (
|
|
|
|
"Please add an explanation below. In the future, "
|
|
|
|
"it is recommended to use `.mute <user> [reason]`"
|
|
|
|
" as the reason is automatically sent to the user."
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
|
|
|
|
add_job("unmute", target.id, {"guild": ctx.guild.id}, expiry_timestamp)
|
|
|
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
await log_channel.send(chan_message)
|
2020-04-21 01:05:32 +03:00
|
|
|
await ctx.send(
|
|
|
|
f"{target.mention} can no longer speak. " f"It will expire {duration_text}."
|
|
|
|
)
|
2018-12-28 00:36:18 +03:00
|
|
|
add_restriction(target.id, config.mute_role)
|
|
|
|
|
|
|
|
|
|
|
|
def setup(bot):
|
|
|
|
bot.add_cog(ModTimed(bot))
|