add logging

This commit is contained in:
Akumatic 2019-01-22 11:38:41 +01:00
parent c64cf7b1d5
commit 32d3f05dd3
2 changed files with 117 additions and 51 deletions

View File

@ -27,7 +27,7 @@ async def on_ready():
@bot.event
async def on_guild_join(guild):
s[str(guild.id)] = {"adminRole": "", "modRole": "", "joinMessage" : "", "suggestionChannel": 0, "modChannel": 0, "announcementChannel": 0, "announcements":0}
s[str(guild.id)] = {"adminRole": "", "modRole": "", "joinMessage": "", "suggestionChannel": 0, "modChannel": 0, "announcementChannel": 0, "announcements": 0, "logEditAndDelete": True, "logEditAndDeleteChannel": 0, "logJoinAndLeave": True, "logJoinAndLeaveChannel" : 0}
writeServer(s)
@bot.event

View File

@ -23,30 +23,55 @@ class Moderation():
#Logs
async def on_member_join(self, member):
if(s[str(member.guild.id)]["joinMessage"] != ""):
await member.send(s[str(member.guild.id)]["joinMessage"])
if(s[str(member.guild.id)]["modChannel"] != 0):
e = discord.Embed(color=0x32c832)
e.set_author(name = str(member) + " has joined the server.", icon_url=member.avatar_url)
e.add_field(name="ID", value=str(member.id), inline=False)
e.add_field(name="Mention", value=member.mention, inline=False)
chan = self.bot.get_channel(s[str(member.guild.id)]["modChannel"])
await chan.send(embed=e)
if s[str(member.guild.id)]["logJoinAndLeave"] == True:
if s[str(member.guild.id)]["joinMessage"] != "":
await member.send(s[str(member.guild.id)]["joinMessage"])
if s[str(member.guild.id)]["logJoinAndLeaveChannel"] != 0:
e = discord.Embed(color=0x32c832)
e.set_author(name = str(member) + " has joined the server.", icon_url=member.avatar_url)
e.add_field(name="ID", value=str(member.id), inline=False)
e.add_field(name="Mention", value=member.mention, inline=False)
chan = self.bot.get_channel(s[str(member.guild.id)]["logJoinAndLeaveChannel"])
await chan.send(embed=e)
async def on_member_remove(self, member):
if(s[str(member.guild.id)]["modChannel"] != 0):
e = discord.Embed(color=0xc83232)
e.set_author(name = str(member) + " has left the server.", icon_url=member.avatar_url)
e.add_field(name="ID", value=str(member.id), inline=False)
e.add_field(name="Mention", value=member.mention, inline=False)
chan = self.bot.get_channel(s[str(member.guild.id)]["modChannel"])
await chan.send(embed=e)
if s[str(member.guild.id)]["logJoinAndLeave"] == True:
if s[str(member.guild.id)]["logJoinAndLeaveChannel"] != 0:
e = discord.Embed(color=0xc83232)
e.set_author(name = str(member) + " has left the server.", icon_url=member.avatar_url)
e.add_field(name="ID", value=str(member.id), inline=False)
e.add_field(name="Mention", value=member.mention, inline=False)
chan = self.bot.get_channel(s[str(member.guild.id)]["logJoinAndLeaveChannel"])
await chan.send(embed=e)
async def on_message_edit(self, before, after):
if s[str(before.guild.id)]["logEditAndDelete"] == True and before.author.bot == False:
if s[str(before.guild.id)]["logEditAndDeleteChannel"] != 0 and before.content != after.content:
e = discord.Embed(color=0xc83232)
e.set_author(name = str(before.author) + " edited a message.", icon_url=before.author.avatar_url)
e.add_field(name="Author ID", value=str(before.author.id), inline=False)
e.add_field(name="Channel", value=str(before.channel.name), inline=False)
e.add_field(name="Message before", value=before.content,inline=False)
e.add_field(name="Message after", value=after.content,inline=False)
chan = self.bot.get_channel(s[str(before.guild.id)]["logEditAndDeleteChannel"])
await chan.send(embed=e)
async def on_message_delete(self, message):
if s[str(message.guild.id)]["logEditAndDelete"] == True and message.author.bot == False:
if s[str(message.guild.id)]["logEditAndDeleteChannel"] != 0:
e = discord.Embed(color=0xc83232)
e.set_author(name = str(message.author) + " deleted a message.", icon_url=message.author.avatar_url)
e.add_field(name="Author ID", value=str(message.author.id), inline=False)
e.add_field(name="Channel", value=str(message.channel.name), inline=False)
e.add_field(name="Message", value=message.content,inline=False)
chan = self.bot.get_channel(s[str(message.guild.id)]["logEditAndDeleteChannel"])
await chan.send(embed=e)
#Groups
@commands.group()
async def mod(self, ctx):
"""Commands usable a Mod"""
if (s[str(ctx.guild.id)]["modRole"] not in [r.name for r in ctx.author.roles]):
if s[str(ctx.guild.id)]["modRole"] not in [r.name for r in ctx.author.roles]:
return
if ctx.invoked_subcommand is None:
await ctx.send(modCommands)
@ -54,7 +79,7 @@ class Moderation():
@commands.group()
async def admin(self, ctx):
"""Commands usable by an Admin"""
if(s[str(ctx.guild.id)]["adminRole"] not in [r.name for r in ctx.author.roles]):
if s[str(ctx.guild.id)]["adminRole"] not in [r.name for r in ctx.author.roles]:
return
if ctx.invoked_subcommand is None:
await ctx.send(adminCommands)
@ -62,7 +87,7 @@ class Moderation():
@commands.group()
async def owner(self, ctx):
"""Commands usable by the Owner"""
if (ctx.author.id != ctx.guild.owner.id):
if ctx.author.id != ctx.guild.owner.id:
return
if ctx.invoked_subcommand is None:
await ctx.send(ownerCommands)
@ -74,36 +99,77 @@ class Moderation():
writeServer(s)
await ctx.send("Join Message sucessfully changed to: " + msg)
@mod.command()
async def setAnnouncementChannel(self, ctx, msg : str):
if(msg not in [c.name for c in ctx.guild.channels]):
return await ctx.send("Channel " + msg + " does not exist")
s[str(ctx.guild.id)]["announcementChannel"] = 465251673762168837
async def setAnnouncementChannel(self, ctx, cid : int = None):
if cid is None:
return await ctx.send("Please specify a channel")
if cid not in [c.id for c in ctx.guild.channels]:
return await ctx.send("Channel " + cid + " does not exist")
s[str(ctx.guild.id)]["announcementChannel"] = cid
writeServer(s)
await ctx.send("Announcement channel set")
@mod.command()
async def setModChannel(self, ctx, msg : str):
if(msg not in [c.name for c in ctx.guild.channels]):
return await ctx.send("Channel " + msg + " does not exist")
s[str(ctx.guild.id)]["modChannel"] = 465251673762168837
async def setModChannel(self, ctx, cid : int = None):
if cid is None:
return await ctx.send("Please specify a channel")
if cid not in [c.id for c in ctx.guild.channels]:
return await ctx.send("Channel " + cid + " does not exist")
s[str(ctx.guild.id)]["modChannel"] = cid
writeServer(s)
await ctx.send("Mod channel set")
@mod.command()
async def setMemberLogChannel(self, ctx, cid : int = None):
if cid is None:
return await ctx.send("Please specify a channel")
if cid not in [c.id for c in ctx.guild.channels]:
return await ctx.send("Channel " + cid + " does not exist")
s[str(ctx.guild.id)]["logJoinAndLeaveChannel"] = cid
writeServer(s)
await ctx.send("Member log channel set")
@mod.command()
async def setMessageChannel(self, ctx, cid : int = None):
if cid is None:
return await ctx.send("Please specify a channel")
if cid not in [c.id for c in ctx.guild.channels]:
return await ctx.send("Channel " + cid + " does not exist")
s[str(ctx.guild.id)]["logEditAndDeleteChannel"] = cid
writeServer(s)
await ctx.send("Message log channel set")
@mod.command()
async def changeMemberLogging(self, ctx):
if s[str(ctx.guild.id)]["logJoinAndLeave"] == True:
s[str(ctx.guild.id)]["logJoinAndLeave"] = False
else:
s[str(ctx.guild.id)]["logJoinAndLeave"] = True
writeServer(s)
await ctx.send("Member logging set to " + str(s[str(ctx.guild.id)]["logJoinAndLeave"]))
@mod.command()
async def changeMessageLogging(self, ctx):
if s[str(ctx.guild.id)]["logEditAndDelete"] == True:
s[str(ctx.guild.id)]["logEditAndDelete"] = False
else:
s[str(ctx.guild.id)]["logEditAndDelete"] = True
writeServer(s)
await ctx.send("Message logging set to " + str(s[str(ctx.guild.id)]["logEditAndDelete"]))
@mod.command()
async def kick(self, ctx, id : int = None, *, msg : str = None):
if(id == None):
if id == None:
return await ctx.send("Missing id")
if(msg == None):
if msg == None:
return await ctx.send("Please specify a reason for kicking this user")
user = ctx.guild.get_member(id)
if user is None:
return await ctx.send("User not Found")
if(s[str(ctx.guild.id)]["modRole"] in [r.name for r in user.roles]):
if s[str(ctx.guild.id)]["modRole"] in [r.name for r in user.roles]:
return await ctx.send("You can't kick this user")
await ctx.guild.kick(user)
if(s[str(ctx.guild.id)]["modChannel"] != 0):
if s[str(ctx.guild.id)]["modChannel"] != 0:
e = discord.Embed(color=0x6428c8)
e.set_author(name = ctx.author.name, icon_url=ctx.author.avatar_url)
e.add_field(name="Kicked:", value=str(user), inline=False)
@ -113,7 +179,7 @@ class Moderation():
@mod.command()
async def announce(self, ctx, *, msg):
if(s[str(ctx.guild.id)]["announcementChannel"] == 0):
if s[str(ctx.guild.id)]["announcementChannel"] == 0:
return await ctx.send("No Channel for Announcements specified. Please set it up first with \"setAnnouncementChannel\"")
else:
e = discord.Embed(color=0x6428c8)
@ -130,10 +196,10 @@ class Moderation():
e = discord.Embed(color=0x6428c8)
for i in s[str(ctx.guild.id)].items():
n = i[0]
if (i[1] == ""):
if i[1] == "":
v = "not set"
elif (i[1] == 0):
if(i[0] == "announcements"):
elif i[1] == 0:
if i[0] == "announcements":
v = 0
else:
v = "not set"
@ -145,13 +211,13 @@ class Moderation():
### Admin Commands ###
@admin.command()
async def addMod(self, ctx, id : int = None):
if (id == None):
if id == None:
return await ctx.send("Missing id")
user = ctx.guild.get_member(id)
if user is None:
return await ctx.send("User not Found")
#Add Mod Role to User
if(s[str(ctx.guild.id)]["modRole"] not in [r.name for r in user.roles]):
if s[str(ctx.guild.id)]["modRole"] not in [r.name for r in user.roles]:
await user.add_roles(discord.utils.get(ctx.guild.roles, name=s[str(ctx.guild.id)]["modRole"]))
await ctx.send("User " + user.name + " was added to " + s[str(ctx.guild.id)]["modRole"])
else:
@ -159,16 +225,16 @@ class Moderation():
@admin.command()
async def rmMod(self, ctx, id : int = None):
if (id == None):
if id == None:
return await ctx.send("Missing id")
user = ctx.guild.get_member(id)
if user is None:
return await ctx.send("User not Found")
if (user.id == ctx.author.id):
if user.id == ctx.author.id:
return await ctx.send("You can't remove yourself from Mods")
if(s[str(ctx.guild.id)]["adminRole"] in [r.name for r in user.roles] and ctx.author.id != ctx.guild.owner.id):
if s[str(ctx.guild.id)]["adminRole"] in [r.name for r in user.roles] and ctx.author.id != ctx.guild.owner.id:
return await ctx.send("You can't remove this ID")
if(s[str(ctx.guild.id)]["modRole"] in [r.name for r in user.roles]):
if s[str(ctx.guild.id)]["modRole"] in [r.name for r in user.roles]:
await user.remove_roles(discord.utils.get(ctx.guild.roles, name=s[str(ctx.guild.id)]["modRole"]))
await ctx.send("User " + user.name + " was removed from " + s[str(ctx.guild.id)]["modRole"])
else:
@ -177,7 +243,7 @@ class Moderation():
### Owner Commands ###
@owner.command()
async def setModRole(self, ctx, msg : str):
if(msg not in [r.name for r in ctx.guild.roles]):
if msg not in [r.name for r in ctx.guild.roles]:
return await ctx.send("Role " + msg + " does not exist")
s[str(ctx.guild.id)]["modRole"] = msg
writeServer(s)
@ -185,7 +251,7 @@ class Moderation():
@owner.command()
async def setAdminRole(self, ctx, msg : str):
if(msg not in [r.name for r in ctx.guild.roles]):
if msg not in [r.name for r in ctx.guild.roles]:
return await ctx.send("Role " + msg + " does not exist")
s[str(ctx.guild.id)]["adminRole"] = msg
writeServer(s)
@ -193,19 +259,19 @@ class Moderation():
@owner.command()
async def addAdmin(self, ctx, id : int = None):
if (id == None):
if id == None:
return await ctx.send("Missing id")
user = ctx.guild.get_member(id)
if user is None:
return await ctx.send("User not Found")
#Add Admin Role to User
if(s[str(ctx.guild.id)]["adminRole"] not in [r.name for r in user.roles]):
if s[str(ctx.guild.id)]["adminRole"] not in [r.name for r in user.roles]:
await user.add_roles(discord.utils.get(ctx.guild.roles, name=s[str(ctx.guild.id)]["adminRole"]))
await ctx.send("User " + user.name + " was added to " + s[str(ctx.guild.id)]["adminRole"])
else:
return await ctx.send("User " + user.name + " is already in " + s[str(ctx.guild.id)]["adminRole"])
#Add Mod Role to User
if(s[str(ctx.guild.id)]["modRole"] not in [r.name for r in user.roles]):
if s[str(ctx.guild.id)]["modRole"] not in [r.name for r in user.roles]:
await user.add_roles(discord.utils.get(ctx.guild.roles, name=s[str(ctx.guild.id)]["modRole"]))
await ctx.send("User " + user.name + " was added to " + s[str(ctx.guild.id)]["modRole"])
else:
@ -213,14 +279,14 @@ class Moderation():
@owner.command()
async def rmAdmin(self, ctx, id : int = None):
if (id == None):
if id == None:
return await ctx.send("Missing id")
user = ctx.guild.get_member(id)
if user is None:
return await ctx.send("User not Found")
if (user.id == ctx.author.id):
if user.id == ctx.author.id:
return await ctx.send("You can't remove yourself from Admins")
if(s[str(ctx.guild.id)]["adminRole"] in [r.name for r in user.roles]):
if s[str(ctx.guild.id)]["adminRole"] in [r.name for r in user.roles]:
await user.remove_roles(discord.utils.get(ctx.guild.roles, name=s[str(ctx.guild.id)]["adminRole"]))
await ctx.send("User " + user.name + " was removed from " + s[str(ctx.guild.id)]["adminRole"])
else: