unban: add unban
This commit is contained in:
parent
09d96591ed
commit
b041a47c3d
3 changed files with 47 additions and 31 deletions
|
@ -233,9 +233,9 @@ class Logs(Cog):
|
||||||
log_channel = self.bot.get_channel(config.log_channel)
|
log_channel = self.bot.get_channel(config.log_channel)
|
||||||
|
|
||||||
msg = (
|
msg = (
|
||||||
"📝 **Message edit**: \n"\
|
"📝 **Message edit**: \n"
|
||||||
f"from {self.bot.escape_message(after.author.name)} "\
|
f"from {self.bot.escape_message(after.author.name)} "
|
||||||
f"({after.author.id}), in {after.channel.mention}:\n"\
|
f"({after.author.id}), in {after.channel.mention}:\n"
|
||||||
f"```{before_content}``` → ```{after_content}```"
|
f"```{before_content}``` → ```{after_content}```"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
61
cogs/mod.py
61
cogs/mod.py
|
@ -25,7 +25,7 @@ class Mod(Cog):
|
||||||
await ctx.send(f"Done!")
|
await ctx.send(f"Done!")
|
||||||
|
|
||||||
log_channel = self.bot.get_channel(config.modlog_channel)
|
log_channel = self.bot.get_channel(config.modlog_channel)
|
||||||
log_msg = f"✏️ **Guild Icon Update**: {ctx.author} " "changed the guild icon."
|
log_msg = f"✏️ **Guild Icon Update**: {ctx.author} changed the guild icon."
|
||||||
img_filename = url.split("/")[-1].split("#")[0] # hacky
|
img_filename = url.split("/")[-1].split("#")[0] # hacky
|
||||||
img_file = discord.File(io.BytesIO(img_bytes), filename=img_filename)
|
img_file = discord.File(io.BytesIO(img_bytes), filename=img_filename)
|
||||||
await log_channel.send(log_msg, file=img_file)
|
await log_channel.send(log_msg, file=img_file)
|
||||||
|
@ -40,11 +40,11 @@ class Mod(Cog):
|
||||||
return await ctx.send("You can't do mod actions on yourself.")
|
return await ctx.send("You can't do mod actions on yourself.")
|
||||||
elif target == self.bot.user:
|
elif target == self.bot.user:
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
f"I'm sorry {ctx.author.mention}, " "I'm afraid I can't do that."
|
f"I'm sorry {ctx.author.mention}, I'm afraid I can't do that."
|
||||||
)
|
)
|
||||||
elif self.check_if_target_is_staff(target):
|
elif self.check_if_target_is_staff(target):
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
"I can't mute this user as " "they're a member of staff."
|
"I can't mute this user as they're a member of staff."
|
||||||
)
|
)
|
||||||
|
|
||||||
userlog(target.id, ctx.author, reason, "mutes", target.name)
|
userlog(target.id, ctx.author, reason, "mutes", target.name)
|
||||||
|
@ -117,11 +117,11 @@ class Mod(Cog):
|
||||||
return await ctx.send("You can't do mod actions on yourself.")
|
return await ctx.send("You can't do mod actions on yourself.")
|
||||||
elif target == self.bot.user:
|
elif target == self.bot.user:
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
f"I'm sorry {ctx.author.mention}, " "I'm afraid I can't do that."
|
f"I'm sorry {ctx.author.mention}, I'm afraid I can't do that."
|
||||||
)
|
)
|
||||||
elif self.check_if_target_is_staff(target):
|
elif self.check_if_target_is_staff(target):
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
"I can't kick this user as " "they're a member of staff."
|
"I can't kick this user as they're a member of staff."
|
||||||
)
|
)
|
||||||
|
|
||||||
userlog(target.id, ctx.author, reason, "kicks", target.name)
|
userlog(target.id, ctx.author, reason, "kicks", target.name)
|
||||||
|
@ -178,12 +178,10 @@ class Mod(Cog):
|
||||||
return await ctx.send("hedgeberg#7337 is now b&. 👍")
|
return await ctx.send("hedgeberg#7337 is now b&. 👍")
|
||||||
elif target == self.bot.user:
|
elif target == self.bot.user:
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
f"I'm sorry {ctx.author.mention}, " "I'm afraid I can't do that."
|
f"I'm sorry {ctx.author.mention}, I'm afraid I can't do that."
|
||||||
)
|
)
|
||||||
elif self.check_if_target_is_staff(target):
|
elif self.check_if_target_is_staff(target):
|
||||||
return await ctx.send(
|
return await ctx.send("I can't ban this user as they're a member of staff.")
|
||||||
"I can't ban this user as " "they're a member of staff."
|
|
||||||
)
|
|
||||||
|
|
||||||
userlog(target.id, ctx.author, reason, "bans", target.name)
|
userlog(target.id, ctx.author, reason, "bans", target.name)
|
||||||
|
|
||||||
|
@ -235,12 +233,10 @@ class Mod(Cog):
|
||||||
return await ctx.send("You can't do mod actions on yourself.")
|
return await ctx.send("You can't do mod actions on yourself.")
|
||||||
elif target == self.bot.user:
|
elif target == self.bot.user:
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
f"I'm sorry {ctx.author.mention}, " "I'm afraid I can't do that."
|
f"I'm sorry {ctx.author.mention}, I'm afraid I can't do that."
|
||||||
)
|
)
|
||||||
elif target_member and self.check_if_target_is_staff(target_member):
|
elif target_member and self.check_if_target_is_staff(target_member):
|
||||||
return await ctx.send(
|
return await ctx.send("I can't ban this user as they're a member of staff.")
|
||||||
"I can't ban this user as " "they're a member of staff."
|
|
||||||
)
|
|
||||||
|
|
||||||
userlog(target, ctx.author, reason, "bans", target_user.name)
|
userlog(target, ctx.author, reason, "bans", target_user.name)
|
||||||
|
|
||||||
|
@ -267,6 +263,35 @@ class Mod(Cog):
|
||||||
await log_channel.send(chan_message)
|
await log_channel.send(chan_message)
|
||||||
await ctx.send(f"{safe_name} is now b&. 👍")
|
await ctx.send(f"{safe_name} is now b&. 👍")
|
||||||
|
|
||||||
|
@commands.guild_only()
|
||||||
|
@commands.bot_has_permissions(ban_members=True)
|
||||||
|
@commands.check(check_if_staff)
|
||||||
|
@commands.command()
|
||||||
|
async def unban(self, ctx, target: int, *, reason: str = ""):
|
||||||
|
"""Unbans a user with their ID, doesn't message them, staff only."""
|
||||||
|
target_user = await self.bot.fetch_user(target)
|
||||||
|
|
||||||
|
safe_name = await commands.clean_content().convert(ctx, str(target))
|
||||||
|
|
||||||
|
await ctx.guild.unban(target_user, reason=f"{ctx.author}, reason: {reason}")
|
||||||
|
chan_message = (
|
||||||
|
f"⚠️ **Unban**: {ctx.author.mention} unbanned "
|
||||||
|
f"{target_user.mention} | {safe_name}\n"
|
||||||
|
f"🏷 __User ID__: {target}\n"
|
||||||
|
)
|
||||||
|
if reason:
|
||||||
|
chan_message += f'✏️ __Reason__: "{reason}"'
|
||||||
|
else:
|
||||||
|
chan_message += (
|
||||||
|
"Please add an explanation below. In the future"
|
||||||
|
", it is recommended to use "
|
||||||
|
"`.unban <user id> [reason]`."
|
||||||
|
)
|
||||||
|
|
||||||
|
log_channel = self.bot.get_channel(config.modlog_channel)
|
||||||
|
await log_channel.send(chan_message)
|
||||||
|
await ctx.send(f"{safe_name} is now unb&.")
|
||||||
|
|
||||||
@commands.guild_only()
|
@commands.guild_only()
|
||||||
@commands.bot_has_permissions(ban_members=True)
|
@commands.bot_has_permissions(ban_members=True)
|
||||||
@commands.check(check_if_staff)
|
@commands.check(check_if_staff)
|
||||||
|
@ -278,12 +303,10 @@ class Mod(Cog):
|
||||||
return await ctx.send("You can't do mod actions on yourself.")
|
return await ctx.send("You can't do mod actions on yourself.")
|
||||||
elif target == self.bot.user:
|
elif target == self.bot.user:
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
f"I'm sorry {ctx.author.mention}, " "I'm afraid I can't do that."
|
f"I'm sorry {ctx.author.mention}, I'm afraid I can't do that."
|
||||||
)
|
)
|
||||||
elif self.check_if_target_is_staff(target):
|
elif self.check_if_target_is_staff(target):
|
||||||
return await ctx.send(
|
return await ctx.send("I can't ban this user as they're a member of staff.")
|
||||||
"I can't ban this user as " "they're a member of staff."
|
|
||||||
)
|
|
||||||
|
|
||||||
userlog(target.id, ctx.author, reason, "bans", target.name)
|
userlog(target.id, ctx.author, reason, "bans", target.name)
|
||||||
|
|
||||||
|
@ -383,11 +406,11 @@ class Mod(Cog):
|
||||||
return await ctx.send("You can't do mod actions on yourself.")
|
return await ctx.send("You can't do mod actions on yourself.")
|
||||||
elif target == self.bot.user:
|
elif target == self.bot.user:
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
f"I'm sorry {ctx.author.mention}, " "I'm afraid I can't do that."
|
f"I'm sorry {ctx.author.mention}, I'm afraid I can't do that."
|
||||||
)
|
)
|
||||||
elif self.check_if_target_is_staff(target):
|
elif self.check_if_target_is_staff(target):
|
||||||
return await ctx.send(
|
return await ctx.send(
|
||||||
"I can't warn this user as " "they're a member of staff."
|
"I can't warn this user as they're a member of staff."
|
||||||
)
|
)
|
||||||
|
|
||||||
log_channel = self.bot.get_channel(config.modlog_channel)
|
log_channel = self.bot.get_channel(config.modlog_channel)
|
||||||
|
|
|
@ -66,11 +66,7 @@ class Verification(Cog):
|
||||||
|
|
||||||
async def do_resetalgo(self, channel, author, limit: int = 100):
|
async def do_resetalgo(self, channel, author, limit: int = 100):
|
||||||
# randomize hash_choice on reset
|
# randomize hash_choice on reset
|
||||||
self.hash_choice = random.choice(
|
self.hash_choice = random.choice(tuple(config.welcome_hashes))
|
||||||
tuple(
|
|
||||||
config.welcome_hashes
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
msg = (
|
msg = (
|
||||||
f"📘 **Reset Algorithm**: {author} reset " f"algorithm in {channel.mention}"
|
f"📘 **Reset Algorithm**: {author} reset " f"algorithm in {channel.mention}"
|
||||||
|
@ -171,10 +167,7 @@ class Verification(Cog):
|
||||||
)
|
)
|
||||||
|
|
||||||
# Detect if the user uses the wrong hash algorithm
|
# Detect if the user uses the wrong hash algorithm
|
||||||
wrong_hash_algos = (
|
wrong_hash_algos = config.welcome_hashes - {self.hash_choice}
|
||||||
config.welcome_hashes
|
|
||||||
- {self.hash_choice}
|
|
||||||
)
|
|
||||||
for algo in wrong_hash_algos:
|
for algo in wrong_hash_algos:
|
||||||
for name in itertools.chain(allowed_names, close_names):
|
for name in itertools.chain(allowed_names, close_names):
|
||||||
if hashlib.new(algo, name.encode("utf-8")).hexdigest() in mcl:
|
if hashlib.new(algo, name.encode("utf-8")).hexdigest() in mcl:
|
||||||
|
|
Loading…
Reference in a new issue