2018-12-23 22:03:40 +03:00
|
|
|
|
import discord
|
|
|
|
|
import json
|
|
|
|
|
import config
|
2018-12-27 14:56:13 +03:00
|
|
|
|
from helpers.restrictions import get_user_restrictions
|
2018-12-23 22:03:40 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Logs:
|
|
|
|
|
"""
|
|
|
|
|
Logs join and leave messages, bans and unbans, and member changes.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
def __init__(self, bot):
|
|
|
|
|
self.bot = bot
|
|
|
|
|
|
|
|
|
|
async def on_member_join(self, member):
|
|
|
|
|
await self.bot.wait_until_ready()
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
|
# We use this a lot, might as well get it once
|
|
|
|
|
escaped_name = self.bot.escape_message(member)
|
|
|
|
|
|
|
|
|
|
# Check if user account is older than 15 minutes
|
|
|
|
|
age = member.joined_at - member.created_at
|
|
|
|
|
if age < config.min_age:
|
|
|
|
|
try:
|
|
|
|
|
await member.send("Your account is too new to join ReSwitched."
|
|
|
|
|
" Please try again later.")
|
|
|
|
|
sent = True
|
|
|
|
|
except discord.errors.Forbidden:
|
|
|
|
|
sent = False
|
|
|
|
|
await member.kick(reason="Too new")
|
|
|
|
|
msg = f"🚨 **Account too new**: {member.mention} | "\
|
|
|
|
|
f"{escaped_name}\n"\
|
|
|
|
|
f"🗓 __Creation__: {member.created_at}\n"\
|
|
|
|
|
f"🕓 Account age: {age}\n"\
|
|
|
|
|
f"🏷 __User ID__: {member.id}"
|
|
|
|
|
if not sent:
|
|
|
|
|
msg += "\nThe user has disabled direct messages,"\
|
|
|
|
|
" so the reason was not sent."
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
return
|
|
|
|
|
msg = f"✅ **Join**: {member.mention} | "\
|
|
|
|
|
f"{escaped_name}\n"\
|
|
|
|
|
f"🗓 __Creation__: {member.created_at}\n"\
|
|
|
|
|
f"🕓 Account age: {age}\n"\
|
|
|
|
|
f"🏷 __User ID__: {member.id}"
|
|
|
|
|
|
2018-12-27 14:56:13 +03:00
|
|
|
|
# Handles user restrictions
|
|
|
|
|
# Basically, gives back muted role to users that leave with it.
|
|
|
|
|
rsts = get_user_restrictions(member.id)
|
|
|
|
|
roles = [discord.utils.get(member.guild.roles, id=rst) for rst in rsts]
|
|
|
|
|
await member.add_roles(*roles)
|
2018-12-24 02:53:14 +03:00
|
|
|
|
|
2018-12-23 22:03:40 +03:00
|
|
|
|
# Real hell zone.
|
2018-12-27 14:32:16 +03:00
|
|
|
|
with open("data/userlog.json", "r") as f:
|
2018-12-23 22:03:40 +03:00
|
|
|
|
warns = json.load(f)
|
|
|
|
|
try:
|
2018-12-24 01:36:36 +03:00
|
|
|
|
if len(warns[str(member.id)]["warns"]) == 0:
|
2018-12-23 22:03:40 +03:00
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
else:
|
|
|
|
|
embed = discord.Embed(color=discord.Color.dark_red(),
|
|
|
|
|
title=f"Warns for {escaped_name}")
|
|
|
|
|
embed.set_thumbnail(url=member.avatar_url)
|
2018-12-24 01:36:36 +03:00
|
|
|
|
for idx, warn in enumerate(warns[str(member.id)]["warns"]):
|
2018-12-23 22:03:40 +03:00
|
|
|
|
embed.add_field(name=f"{idx + 1}: {warn['timestamp']}",
|
|
|
|
|
value=f"Issuer: {warn['issuer_name']}"
|
|
|
|
|
f"\nReason: {warn['reason']}")
|
|
|
|
|
await log_channel.send(msg, embed=embed)
|
|
|
|
|
except KeyError: # if the user is not in the file
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
|
2019-01-29 13:51:43 +03:00
|
|
|
|
async def on_message_edit(self, before, after):
|
|
|
|
|
await self.bot.wait_until_ready()
|
|
|
|
|
if after.channel.id not in config.spy_channels:
|
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
|
msg = "📝 **Message edit**: \n"\
|
|
|
|
|
f"from {self.bot.escape_message(after.author.name)} "\
|
|
|
|
|
f"({after.author.id})\n"\
|
|
|
|
|
f"`{before.clean_content}` → `{after.clean_content}`"
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
|
|
|
|
|
async def on_message_delete(self, message):
|
|
|
|
|
await self.bot.wait_until_ready()
|
|
|
|
|
if message.channel.id not in config.spy_channels:
|
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
|
msg = "🗑️ **Message delete**: \n"\
|
|
|
|
|
f"from {self.bot.escape_message(message.author.name)} "\
|
|
|
|
|
f"({message.author.id})\n `{message.clean_content}`"
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
|
2018-12-23 22:03:40 +03:00
|
|
|
|
async def on_member_remove(self, member):
|
|
|
|
|
await self.bot.wait_until_ready()
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
|
msg = f"⬅️ **Leave**: {member.mention} | "\
|
|
|
|
|
f"{self.bot.escape_message(member)}\n"\
|
|
|
|
|
f"🏷 __User ID__: {member.id}"
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
|
2018-12-25 14:13:02 +03:00
|
|
|
|
async def on_member_ban(self, guild, member):
|
2018-12-23 22:03:40 +03:00
|
|
|
|
await self.bot.wait_until_ready()
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
|
msg = f"⛔ **Ban**: {member.mention} | "\
|
|
|
|
|
f"{self.bot.escape_message(member)}\n"\
|
|
|
|
|
f"🏷 __User ID__: {member.id}"
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
|
2018-12-25 14:13:02 +03:00
|
|
|
|
async def on_member_unban(self, guild, user):
|
2018-12-23 22:03:40 +03:00
|
|
|
|
await self.bot.wait_until_ready()
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
|
msg = f"⚠️ **Unban**: {user.mention} | "\
|
|
|
|
|
f"{self.bot.escape_message(user)}\n"\
|
|
|
|
|
f"🏷 __User ID__: {user.id}"
|
|
|
|
|
# if user.id in self.bot.timebans:
|
|
|
|
|
# msg += "\nTimeban removed."
|
|
|
|
|
# self.bot.timebans.pop(user.id)
|
|
|
|
|
# with open("data/timebans.json", "r") as f:
|
|
|
|
|
# timebans = json.load(f)
|
|
|
|
|
# if user.id in timebans:
|
|
|
|
|
# timebans.pop(user.id)
|
|
|
|
|
# with open("data/timebans.json", "w") as f:
|
|
|
|
|
# json.dump(timebans, f)
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
|
|
|
|
|
async def on_member_update(self, member_before, member_after):
|
|
|
|
|
await self.bot.wait_until_ready()
|
|
|
|
|
msg = ""
|
|
|
|
|
log_channel = self.bot.get_channel(config.log_channel)
|
|
|
|
|
if member_before.roles != member_after.roles:
|
|
|
|
|
# role removal
|
|
|
|
|
role_removal = []
|
|
|
|
|
for index, role in enumerate(member_before.roles):
|
|
|
|
|
if role not in member_after.roles:
|
|
|
|
|
role_removal.append(role)
|
|
|
|
|
# role addition
|
|
|
|
|
role_addition = []
|
|
|
|
|
for index, role in enumerate(member_after.roles):
|
|
|
|
|
if role not in member_before.roles:
|
|
|
|
|
role_addition.append(role)
|
|
|
|
|
|
|
|
|
|
if len(role_addition) != 0 or len(role_removal) != 0:
|
|
|
|
|
msg += "\n👑 __Role change__: "
|
|
|
|
|
roles = []
|
|
|
|
|
for role in role_removal:
|
|
|
|
|
roles.append("_~~" + role.name + "~~_")
|
|
|
|
|
for role in role_addition:
|
|
|
|
|
roles.append("__**" + role.name + "**__")
|
|
|
|
|
for index, role in enumerate(member_after.roles):
|
|
|
|
|
if role.name == "@everyone":
|
|
|
|
|
continue
|
|
|
|
|
if role not in role_removal and role not in role_addition:
|
|
|
|
|
roles.append(role.name)
|
|
|
|
|
msg += ", ".join(roles)
|
|
|
|
|
|
|
|
|
|
if member_before.name != member_after.name:
|
|
|
|
|
msg += "\n📝 __Username change__: "\
|
|
|
|
|
f"{self.bot.escape_message(member_before)} → "\
|
|
|
|
|
f"{self.bot.escape_message(member_after)}"
|
|
|
|
|
if member_before.nick != member_after.nick:
|
|
|
|
|
if not member_before.nick:
|
|
|
|
|
msg += "\n🏷 __Nickname addition__"
|
|
|
|
|
elif not member_after.nick:
|
|
|
|
|
msg += "\n🏷 __Nickname removal__"
|
|
|
|
|
else:
|
|
|
|
|
msg += "\n🏷 __Nickname change__"
|
|
|
|
|
msg += f": {self.bot.escape_message(member_before.nick)} → "\
|
|
|
|
|
f"{self.bot.escape_message(member_after.nick)}"
|
|
|
|
|
if msg:
|
|
|
|
|
msg = f"ℹ️ **Member update**: {member_after.mention} | "\
|
|
|
|
|
f"{self.bot.escape_message(member_after)}{msg}"
|
|
|
|
|
await log_channel.send(msg)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def setup(bot):
|
|
|
|
|
bot.add_cog(Logs(bot))
|