2016-07-09 13:27:19 +12:00
|
|
|
from discord.ext import commands
|
|
|
|
from .utils import checks
|
2016-07-10 03:17:54 +12:00
|
|
|
from .utils import config
|
2016-07-10 03:40:46 +12:00
|
|
|
import pymysql
|
2016-07-16 02:58:10 +12:00
|
|
|
import discord
|
|
|
|
|
2016-07-16 09:39:26 +12:00
|
|
|
valid_perms = ['kick_members', 'ban_members', 'administrator', 'manage_channels', 'manage_server', 'read_messages',
|
|
|
|
'send_messages', 'send_tts_messages', 'manage_messages', 'embed_links', 'attach_files',
|
|
|
|
'read_message_history',
|
|
|
|
'mention_everyone', 'connect', 'speak', 'mute_members', 'deafen_members', 'move_members',
|
|
|
|
'use_voice_activation',
|
|
|
|
'change_nicknames', 'manage_nicknames', 'manage_roles']
|
|
|
|
|
2016-07-09 13:27:19 +12:00
|
|
|
|
|
|
|
class Mod:
|
2016-07-09 13:59:10 +12:00
|
|
|
"""Commands that can be used by a or an admin, depending on the command"""
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-09 13:27:19 +12:00
|
|
|
def __init__(self, bot):
|
|
|
|
self.bot = bot
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-10 07:38:48 +12:00
|
|
|
@commands.group(pass_context=True)
|
2016-07-10 07:39:32 +12:00
|
|
|
async def nsfw(self, ctx):
|
2016-07-10 07:40:51 +12:00
|
|
|
"""Handles adding or removing a channel as a nsfw channel"""
|
2016-07-10 07:38:48 +12:00
|
|
|
if ctx.invoked_subcommand is None:
|
|
|
|
await self.bot.say('Invalid subcommand passed: {0.subcommand_passed}'.format(ctx))
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-10 07:38:48 +12:00
|
|
|
@nsfw.command(name="add", pass_context=True)
|
2016-07-16 10:46:10 +12:00
|
|
|
@checks.customPermsOrRole("kick_members")
|
2016-07-10 07:38:48 +12:00
|
|
|
async def nsfw_add(self, ctx):
|
2016-07-10 06:27:14 +12:00
|
|
|
"""Registers this channel as a 'nsfw' channel"""
|
2016-07-10 04:02:33 +12:00
|
|
|
cursor = config.getCursor()
|
2016-07-10 03:17:54 +12:00
|
|
|
cursor.execute('use {}'.format(config.db_default))
|
2016-07-10 03:26:13 +12:00
|
|
|
try:
|
|
|
|
cursor.execute('insert into nsfw_channels (channel_id) values ("{}")'.format(ctx.message.channel.id))
|
|
|
|
except pymysql.IntegrityError:
|
|
|
|
await self.bot.say("This channel is already registered as 'nsfw'!")
|
2016-07-10 04:54:24 +12:00
|
|
|
config.closeConnection()
|
2016-07-10 03:41:44 +12:00
|
|
|
return
|
2016-07-10 04:33:48 +12:00
|
|
|
config.closeConnection()
|
2016-07-10 03:26:13 +12:00
|
|
|
await self.bot.say("This channel has just been registered as 'nsfw'! Have fun you naughties ;)")
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-10 07:38:48 +12:00
|
|
|
@nsfw.command(name="remove", aliases=["delete"], pass_context=True)
|
2016-07-16 10:46:10 +12:00
|
|
|
@checks.customPermsOrRole("kick_members")
|
2016-07-10 07:38:48 +12:00
|
|
|
async def nsfw_remove(self, ctx):
|
2016-07-10 04:28:18 +12:00
|
|
|
"""Removes this channel as a 'nsfw' channel"""
|
2016-07-10 04:25:28 +12:00
|
|
|
cursor = config.getCursor()
|
|
|
|
cursor.execute('use {}'.format(config.db_default))
|
2016-07-10 04:54:24 +12:00
|
|
|
cursor.execute('select * from nsfw_channels where channel_id="{}"'.format(ctx.message.channel.id))
|
|
|
|
if cursor.fetchone() is None:
|
2016-07-10 04:25:28 +12:00
|
|
|
await self.bot.say("This channel is not registered as a ''nsfw' channel!")
|
2016-07-10 04:54:24 +12:00
|
|
|
config.closeConnection()
|
2016-07-10 04:25:28 +12:00
|
|
|
return
|
2016-07-10 04:54:24 +12:00
|
|
|
|
|
|
|
cursor.execute('delete from nsfw_channels where channel_id="{}"'.format(ctx.message.channel.id))
|
2016-07-10 04:33:48 +12:00
|
|
|
config.closeConnection()
|
2016-07-10 04:25:28 +12:00
|
|
|
await self.bot.say("This channel has just been unregistered as a nsfw channel")
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-09 13:27:19 +12:00
|
|
|
@commands.command(pass_context=True, no_pm=True)
|
2016-07-16 10:46:10 +12:00
|
|
|
@checks.customPermsOrRole("manage_server")
|
2016-07-09 13:27:19 +12:00
|
|
|
async def leave(self, ctx):
|
|
|
|
"""Forces the bot to leave the server"""
|
2016-07-10 00:57:25 +12:00
|
|
|
await self.bot.say('Why must I leave? Hopefully I can come back :c')
|
|
|
|
await self.bot.leave_server(ctx.message.server)
|
2016-07-09 13:27:19 +12:00
|
|
|
|
2016-07-10 07:14:38 +12:00
|
|
|
@commands.command(pass_context=True)
|
2016-07-16 10:46:10 +12:00
|
|
|
@checks.customPermsOrRole("kick_members")
|
2016-07-10 07:14:38 +12:00
|
|
|
async def say(self, ctx, *msg: str):
|
|
|
|
"""Tells the bot to repeat what you say"""
|
|
|
|
msg = ' '.join(msg)
|
|
|
|
await self.bot.say(msg)
|
|
|
|
await self.bot.delete_message(ctx.message)
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-16 01:27:00 +12:00
|
|
|
@commands.group(pass_context=True, invoke_without_command=True)
|
2016-07-16 10:23:13 +12:00
|
|
|
async def perms(self, ctx, *command: str):
|
|
|
|
if command is None:
|
2016-07-16 07:16:10 +12:00
|
|
|
await self.bot.say("Valid permissions are: ```{}```".format("\n".join("{}".format(i) for i in valid_perms)))
|
|
|
|
return
|
2016-07-16 10:23:13 +12:00
|
|
|
command = " ".join(command)
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-16 01:56:13 +12:00
|
|
|
cursor = config.getCursor()
|
2016-07-16 07:20:29 +12:00
|
|
|
cursor.execute('use {}'.format(config.db_perms))
|
2016-07-16 01:56:13 +12:00
|
|
|
cursor.execute("show tables like '{}'".format(ctx.message.server.id))
|
|
|
|
result = cursor.fetchone()
|
|
|
|
if result is None:
|
|
|
|
await self.bot.say("There are no custom permissions setup on this server yet!")
|
|
|
|
return
|
2016-07-16 09:39:26 +12:00
|
|
|
sql = "select perms from `" + ctx.message.server.id + "` where command=%s"
|
2016-07-16 07:22:04 +12:00
|
|
|
cursor.execute(sql, (command,))
|
2016-07-16 01:56:13 +12:00
|
|
|
result = cursor.fetchone()
|
|
|
|
if result is None:
|
|
|
|
await self.bot.say("That command has no custom permissions setup on it!")
|
|
|
|
return
|
2016-07-16 09:39:26 +12:00
|
|
|
|
|
|
|
await self.bot.say(
|
|
|
|
"You need to have the permission `{}` to use the command `{}` in this server".format(result['perms'],
|
|
|
|
command))
|
|
|
|
|
2016-07-16 01:56:13 +12:00
|
|
|
@perms.command(name="add", aliases=["setup,create"], pass_context=True)
|
2016-07-16 10:46:10 +12:00
|
|
|
@checks.customPermsOrRole("manage_server")
|
2016-07-16 10:18:04 +12:00
|
|
|
async def add_perms(self, ctx, *msg: str):
|
|
|
|
command = " ".join(msg[0:len(msg)-1])
|
|
|
|
permissions = msg[len(msg)-1]
|
|
|
|
msg = msg[0:len(msg)-1]
|
|
|
|
count = 0
|
|
|
|
cmd = self.bot.commands.get(msg[count])
|
|
|
|
while isinstance(cmd, commands.Group):
|
|
|
|
count += 1
|
2016-07-16 10:41:16 +12:00
|
|
|
try:
|
|
|
|
cmd = cmd.commands.get(msg[count])
|
|
|
|
except:
|
|
|
|
break
|
2016-07-16 10:46:10 +12:00
|
|
|
|
2016-07-16 10:18:04 +12:00
|
|
|
for check in cmd.checks:
|
2016-07-16 09:39:26 +12:00
|
|
|
if "isOwner" == check.__name__:
|
2016-07-16 07:16:10 +12:00
|
|
|
await self.bot.say("This command cannot have custom permissions setup!")
|
|
|
|
return
|
2016-07-16 09:39:26 +12:00
|
|
|
|
2016-07-16 07:16:10 +12:00
|
|
|
if getattr(discord.Permissions, permissions, None) is None and not permissions.lower() == "none":
|
|
|
|
await self.bot.say("{} does not appear to be a valid permission! Valid permissions are: ```{}```"
|
2016-07-16 09:39:26 +12:00
|
|
|
.format(permissions, "\n".join(valid_perms)))
|
2016-07-16 07:16:10 +12:00
|
|
|
else:
|
|
|
|
cursor = config.getCursor()
|
|
|
|
cursor.execute('use {}'.format(config.db_perms))
|
|
|
|
cursor.execute("show tables like %s", (ctx.message.server.id,))
|
|
|
|
result = cursor.fetchone()
|
|
|
|
if result is None:
|
2016-07-16 09:39:26 +12:00
|
|
|
# Server's data doesn't exist yet, need to create it
|
|
|
|
sql = "create table `" + ctx.message.server.id + "` (`command` varchar(32) not null,`perms` " \
|
|
|
|
"varchar(32) not null,primary key (`command`))" \
|
|
|
|
" engine=InnoDB default charset=utf8 collate=utf8_bin"
|
2016-07-16 07:16:10 +12:00
|
|
|
cursor.execute(sql)
|
2016-07-16 09:39:26 +12:00
|
|
|
sql = "insert into `" + ctx.message.server.id + "` (command, perms) values(%s, %s)"
|
|
|
|
cursor.execute(sql, (command, permissions))
|
2016-07-16 02:58:10 +12:00
|
|
|
else:
|
2016-07-16 09:39:26 +12:00
|
|
|
sql = "select perms from `" + ctx.message.server.id + "`where command=%s"
|
|
|
|
cursor.execute(sql, (command,))
|
2016-07-16 07:16:10 +12:00
|
|
|
if cursor.fetchone() is None:
|
2016-07-16 09:39:26 +12:00
|
|
|
sql = "insert into `" + ctx.message.server.id + "` (command, perms) values(%s, %s)"
|
|
|
|
cursor.execute(sql, (command, permissions))
|
2016-07-16 02:58:10 +12:00
|
|
|
else:
|
2016-07-16 09:39:26 +12:00
|
|
|
sql = "update `" + ctx.message.server.id + "` set perms=%s where command=%s"
|
|
|
|
cursor.execute(sql, (permissions, command))
|
|
|
|
|
|
|
|
await self.bot.say("I have just added your custom permissions; "
|
|
|
|
"you now need to have `{}` permissions to use the command `{}`".format(permissions, command))
|
2016-07-16 07:16:10 +12:00
|
|
|
config.closeConnection()
|
2016-07-09 13:31:18 +12:00
|
|
|
|
|
|
|
|
|
|
|
def setup(bot):
|
|
|
|
bot.add_cog(Mod(bot))
|