|
|
@ -19,10 +19,7 @@ class CCRole(Cog):
|
|
|
|
def __init__(self, bot):
|
|
|
|
def __init__(self, bot):
|
|
|
|
self.bot = bot
|
|
|
|
self.bot = bot
|
|
|
|
self.config = Config.get_conf(self, identifier=9999114111108101)
|
|
|
|
self.config = Config.get_conf(self, identifier=9999114111108101)
|
|
|
|
default_guild = {
|
|
|
|
default_guild = {"cmdlist": {}, "settings": {}}
|
|
|
|
"cmdlist": {},
|
|
|
|
|
|
|
|
"settings": {}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.config.register_guild(**default_guild)
|
|
|
|
self.config.register_guild(**default_guild)
|
|
|
|
|
|
|
|
|
|
|
@ -54,17 +51,23 @@ class CCRole(Cog):
|
|
|
|
cmd_list = self.config.guild(guild).cmdlist
|
|
|
|
cmd_list = self.config.guild(guild).cmdlist
|
|
|
|
|
|
|
|
|
|
|
|
if await cmd_list.get_raw(command, default=None):
|
|
|
|
if await cmd_list.get_raw(command, default=None):
|
|
|
|
await ctx.send("This command already exists. Delete it with `{}ccrole delete` first.".format(ctx.prefix))
|
|
|
|
await ctx.send(
|
|
|
|
|
|
|
|
"This command already exists. Delete it with `{}ccrole delete` first.".format(
|
|
|
|
|
|
|
|
ctx.prefix
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
# Roles to add
|
|
|
|
# Roles to add
|
|
|
|
await ctx.send('What roles should it add? (Must be **comma separated**)\nSay `None` to skip adding roles')
|
|
|
|
await ctx.send(
|
|
|
|
|
|
|
|
"What roles should it add? (Must be **comma separated**)\nSay `None` to skip adding roles"
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def check(m):
|
|
|
|
def check(m):
|
|
|
|
return m.author == author and m.channel == channel
|
|
|
|
return m.author == author and m.channel == channel
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
answer = await self.bot.wait_for('message', timeout=120, check=check)
|
|
|
|
answer = await self.bot.wait_for("message", timeout=120, check=check)
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
return
|
|
|
|
return
|
|
|
@ -77,9 +80,11 @@ class CCRole(Cog):
|
|
|
|
return
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
# Roles to remove
|
|
|
|
# Roles to remove
|
|
|
|
await ctx.send('What roles should it remove? (Must be comma separated)\nSay `None` to skip removing roles')
|
|
|
|
await ctx.send(
|
|
|
|
|
|
|
|
"What roles should it remove? (Must be comma separated)\nSay `None` to skip removing roles"
|
|
|
|
|
|
|
|
)
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
answer = await self.bot.wait_for('message', timeout=120, check=check)
|
|
|
|
answer = await self.bot.wait_for("message", timeout=120, check=check)
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
return
|
|
|
|
return
|
|
|
@ -93,10 +98,11 @@ class CCRole(Cog):
|
|
|
|
|
|
|
|
|
|
|
|
# Roles to use
|
|
|
|
# Roles to use
|
|
|
|
await ctx.send(
|
|
|
|
await ctx.send(
|
|
|
|
'What roles are allowed to use this command? (Must be comma separated)\nSay `None` to allow all roles')
|
|
|
|
"What roles are allowed to use this command? (Must be comma separated)\nSay `None` to allow all roles"
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
answer = await self.bot.wait_for('message', timeout=120, check=check)
|
|
|
|
answer = await self.bot.wait_for("message", timeout=120, check=check)
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
return
|
|
|
|
return
|
|
|
@ -109,10 +115,12 @@ class CCRole(Cog):
|
|
|
|
return
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
# Selfrole
|
|
|
|
# Selfrole
|
|
|
|
await ctx.send('Is this a targeted command?(yes//no)\nNo will make this a selfrole command')
|
|
|
|
await ctx.send(
|
|
|
|
|
|
|
|
"Is this a targeted command?(yes//no)\nNo will make this a selfrole command"
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
answer = await self.bot.wait_for('message', timeout=120, check=check)
|
|
|
|
answer = await self.bot.wait_for("message", timeout=120, check=check)
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
return
|
|
|
|
return
|
|
|
@ -126,13 +134,14 @@ class CCRole(Cog):
|
|
|
|
|
|
|
|
|
|
|
|
# Message to send
|
|
|
|
# Message to send
|
|
|
|
await ctx.send(
|
|
|
|
await ctx.send(
|
|
|
|
'What message should the bot say when using this command?\n'
|
|
|
|
"What message should the bot say when using this command?\n"
|
|
|
|
'Say `None` to send the default `Success!` message\n'
|
|
|
|
"Say `None` to send the default `Success!` message\n"
|
|
|
|
'Eval Options: `{author}`, `{target}`, `{server}`, `{channel}`, `{message}`\n'
|
|
|
|
"Eval Options: `{author}`, `{target}`, `{server}`, `{channel}`, `{message}`\n"
|
|
|
|
'For example: `Welcome {target.mention} to {server.name}!`')
|
|
|
|
"For example: `Welcome {target.mention} to {server.name}!`"
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
answer = await self.bot.wait_for('message', timeout=120, check=check)
|
|
|
|
answer = await self.bot.wait_for("message", timeout=120, check=check)
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
except asyncio.TimeoutError:
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
await ctx.send("Timed out, canceling")
|
|
|
|
return
|
|
|
|
return
|
|
|
@ -143,7 +152,13 @@ class CCRole(Cog):
|
|
|
|
|
|
|
|
|
|
|
|
# Save the command
|
|
|
|
# Save the command
|
|
|
|
|
|
|
|
|
|
|
|
out = {'text': text, 'aroles': arole_list, 'rroles': rrole_list, "proles": prole_list, "targeted": targeted}
|
|
|
|
out = {
|
|
|
|
|
|
|
|
"text": text,
|
|
|
|
|
|
|
|
"aroles": arole_list,
|
|
|
|
|
|
|
|
"rroles": rrole_list,
|
|
|
|
|
|
|
|
"proles": prole_list,
|
|
|
|
|
|
|
|
"targeted": targeted,
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
await cmd_list.set_raw(command, value=out)
|
|
|
|
await cmd_list.set_raw(command, value=out)
|
|
|
|
|
|
|
|
|
|
|
@ -174,18 +189,24 @@ class CCRole(Cog):
|
|
|
|
await ctx.send("That command doesn't exist")
|
|
|
|
await ctx.send("That command doesn't exist")
|
|
|
|
return
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
embed = discord.Embed(title=command,
|
|
|
|
embed = discord.Embed(
|
|
|
|
description="{} custom command".format("Targeted" if cmd['targeted'] else "Non-Targeted"))
|
|
|
|
title=command,
|
|
|
|
|
|
|
|
description="{} custom command".format(
|
|
|
|
|
|
|
|
"Targeted" if cmd["targeted"] else "Non-Targeted"
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def process_roles(role_list):
|
|
|
|
def process_roles(role_list):
|
|
|
|
if not role_list:
|
|
|
|
if not role_list:
|
|
|
|
return "None"
|
|
|
|
return "None"
|
|
|
|
return ", ".join([discord.utils.get(ctx.guild.roles, id=roleid).name for roleid in role_list])
|
|
|
|
return ", ".join(
|
|
|
|
|
|
|
|
[discord.utils.get(ctx.guild.roles, id=roleid).name for roleid in role_list]
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
embed.add_field(name="Text", value="```{}```".format(cmd['text']))
|
|
|
|
embed.add_field(name="Text", value="```{}```".format(cmd["text"]))
|
|
|
|
embed.add_field(name="Adds Roles", value=process_roles(cmd['aroles']), inline=True)
|
|
|
|
embed.add_field(name="Adds Roles", value=process_roles(cmd["aroles"]), inline=True)
|
|
|
|
embed.add_field(name="Removes Roles", value=process_roles(cmd['rroles']), inline=True)
|
|
|
|
embed.add_field(name="Removes Roles", value=process_roles(cmd["rroles"]), inline=True)
|
|
|
|
embed.add_field(name="Role Restrictions", value=process_roles(cmd['proles']), inline=True)
|
|
|
|
embed.add_field(name="Role Restrictions", value=process_roles(cmd["proles"]), inline=True)
|
|
|
|
|
|
|
|
|
|
|
|
await ctx.send(embed=embed)
|
|
|
|
await ctx.send(embed=embed)
|
|
|
|
|
|
|
|
|
|
|
@ -198,13 +219,17 @@ class CCRole(Cog):
|
|
|
|
if not cmd_list:
|
|
|
|
if not cmd_list:
|
|
|
|
await ctx.send(
|
|
|
|
await ctx.send(
|
|
|
|
"There are no custom commands in this server. Use `{}ccrole add` to start adding some.".format(
|
|
|
|
"There are no custom commands in this server. Use `{}ccrole add` to start adding some.".format(
|
|
|
|
ctx.prefix))
|
|
|
|
ctx.prefix
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
cmd_list = ", ".join([ctx.prefix + c for c in sorted(cmd_list.keys())])
|
|
|
|
cmd_list = ", ".join([ctx.prefix + c for c in sorted(cmd_list.keys())])
|
|
|
|
cmd_list = "Custom commands:\n\n" + cmd_list
|
|
|
|
cmd_list = "Custom commands:\n\n" + cmd_list
|
|
|
|
|
|
|
|
|
|
|
|
if len(cmd_list) < 1500: # I'm allowed to have arbitrary numbers for when it's too much to dm dammit
|
|
|
|
if (
|
|
|
|
|
|
|
|
len(cmd_list) < 1500
|
|
|
|
|
|
|
|
): # I'm allowed to have arbitrary numbers for when it's too much to dm dammit
|
|
|
|
await ctx.send(box(cmd_list))
|
|
|
|
await ctx.send(box(cmd_list))
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
for page in pagify(cmd_list, delims=[" ", "\n"]):
|
|
|
|
for page in pagify(cmd_list, delims=[" ", "\n"]):
|
|
|
@ -231,7 +256,10 @@ class CCRole(Cog):
|
|
|
|
async def _get_roles_from_content(self, ctx, content):
|
|
|
|
async def _get_roles_from_content(self, ctx, content):
|
|
|
|
content_list = content.split(",")
|
|
|
|
content_list = content.split(",")
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
role_list = [discord.utils.get(ctx.guild.roles, name=role.strip(' ')).id for role in content_list]
|
|
|
|
role_list = [
|
|
|
|
|
|
|
|
discord.utils.get(ctx.guild.roles, name=role.strip(" ")).id
|
|
|
|
|
|
|
|
for role in content_list
|
|
|
|
|
|
|
|
]
|
|
|
|
except (discord.HTTPException, AttributeError): # None.id is attribute error
|
|
|
|
except (discord.HTTPException, AttributeError): # None.id is attribute error
|
|
|
|
return None
|
|
|
|
return None
|
|
|
|
else:
|
|
|
|
else:
|
|
|
@ -249,9 +277,7 @@ class CCRole(Cog):
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
content = message.content
|
|
|
|
content = message.content
|
|
|
|
prefix_list = await self.bot.command_prefix(self.bot, message)
|
|
|
|
prefix_list = await self.bot.command_prefix(self.bot, message)
|
|
|
|
prefixes = sorted(prefix_list,
|
|
|
|
prefixes = sorted(prefix_list, key=lambda pfx: len(pfx), reverse=True)
|
|
|
|
key=lambda pfx: len(pfx),
|
|
|
|
|
|
|
|
reverse=True)
|
|
|
|
|
|
|
|
for p in prefixes:
|
|
|
|
for p in prefixes:
|
|
|
|
if content.startswith(p):
|
|
|
|
if content.startswith(p):
|
|
|
|
return p
|
|
|
|
return p
|
|
|
@ -259,25 +285,32 @@ class CCRole(Cog):
|
|
|
|
|
|
|
|
|
|
|
|
async def eval_cc(self, cmd, message):
|
|
|
|
async def eval_cc(self, cmd, message):
|
|
|
|
"""Does all the work"""
|
|
|
|
"""Does all the work"""
|
|
|
|
if cmd['proles'] and not (set(role.id for role in message.author.roles) & set(cmd['proles'])):
|
|
|
|
if cmd["proles"] and not (
|
|
|
|
|
|
|
|
set(role.id for role in message.author.roles) & set(cmd["proles"])
|
|
|
|
|
|
|
|
):
|
|
|
|
return # Not authorized, do nothing
|
|
|
|
return # Not authorized, do nothing
|
|
|
|
|
|
|
|
|
|
|
|
if cmd['targeted']:
|
|
|
|
if cmd["targeted"]:
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
target = discord.utils.get(message.guild.members, mention=message.content.split()[1])
|
|
|
|
target = discord.utils.get(
|
|
|
|
|
|
|
|
message.guild.members, mention=message.content.split()[1]
|
|
|
|
|
|
|
|
)
|
|
|
|
except IndexError: # .split() return list of len<2
|
|
|
|
except IndexError: # .split() return list of len<2
|
|
|
|
target = None
|
|
|
|
target = None
|
|
|
|
|
|
|
|
|
|
|
|
if not target:
|
|
|
|
if not target:
|
|
|
|
out_message = "This custom command is targeted! @mention a target\n`{} <target>`".format(
|
|
|
|
out_message = "This custom command is targeted! @mention a target\n`{} <target>`".format(
|
|
|
|
message.content.split()[0])
|
|
|
|
message.content.split()[0]
|
|
|
|
|
|
|
|
)
|
|
|
|
await message.channel.send(out_message)
|
|
|
|
await message.channel.send(out_message)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
target = message.author
|
|
|
|
target = message.author
|
|
|
|
|
|
|
|
|
|
|
|
if cmd['aroles']:
|
|
|
|
if cmd["aroles"]:
|
|
|
|
arole_list = [discord.utils.get(message.guild.roles, id=roleid) for roleid in cmd['aroles']]
|
|
|
|
arole_list = [
|
|
|
|
|
|
|
|
discord.utils.get(message.guild.roles, id=roleid) for roleid in cmd["aroles"]
|
|
|
|
|
|
|
|
]
|
|
|
|
# await self.bot.send_message(message.channel, "Adding: "+str([str(arole) for arole in arole_list]))
|
|
|
|
# await self.bot.send_message(message.channel, "Adding: "+str([str(arole) for arole in arole_list]))
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
await target.add_roles(*arole_list)
|
|
|
|
await target.add_roles(*arole_list)
|
|
|
@ -285,8 +318,10 @@ class CCRole(Cog):
|
|
|
|
await message.channel.send("Permission error: Unable to add roles")
|
|
|
|
await message.channel.send("Permission error: Unable to add roles")
|
|
|
|
await asyncio.sleep(1)
|
|
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
|
|
|
|
|
|
if cmd['rroles']:
|
|
|
|
if cmd["rroles"]:
|
|
|
|
rrole_list = [discord.utils.get(message.guild.roles, id=roleid) for roleid in cmd['rroles']]
|
|
|
|
rrole_list = [
|
|
|
|
|
|
|
|
discord.utils.get(message.guild.roles, id=roleid) for roleid in cmd["rroles"]
|
|
|
|
|
|
|
|
]
|
|
|
|
# await self.bot.send_message(message.channel, "Removing: "+str([str(rrole) for rrole in rrole_list]))
|
|
|
|
# await self.bot.send_message(message.channel, "Removing: "+str([str(rrole) for rrole in rrole_list]))
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
await target.remove_roles(*rrole_list)
|
|
|
|
await target.remove_roles(*rrole_list)
|
|
|
@ -297,7 +332,7 @@ class CCRole(Cog):
|
|
|
|
await message.channel.send(out_message)
|
|
|
|
await message.channel.send(out_message)
|
|
|
|
|
|
|
|
|
|
|
|
def format_cc(self, cmd, message, target):
|
|
|
|
def format_cc(self, cmd, message, target):
|
|
|
|
out = cmd['text']
|
|
|
|
out = cmd["text"]
|
|
|
|
results = re.findall("{([^}]+)\}", out)
|
|
|
|
results = re.findall("{([^}]+)\}", out)
|
|
|
|
for result in results:
|
|
|
|
for result in results:
|
|
|
|
param = self.transform_parameter(result, message, target)
|
|
|
|
param = self.transform_parameter(result, message, target)
|
|
|
@ -316,7 +351,7 @@ class CCRole(Cog):
|
|
|
|
"channel": message.channel,
|
|
|
|
"channel": message.channel,
|
|
|
|
"server": message.guild,
|
|
|
|
"server": message.guild,
|
|
|
|
"guild": message.guild,
|
|
|
|
"guild": message.guild,
|
|
|
|
"target": target
|
|
|
|
"target": target,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if result in objects:
|
|
|
|
if result in objects:
|
|
|
|
return str(objects[result])
|
|
|
|
return str(objects[result])
|
|
|
|