Add extension pcp
This commit is contained in:
parent
af97508d23
commit
9756103467
2 changed files with 163 additions and 0 deletions
|
@ -9,3 +9,4 @@ bot.load_extension("extensions.greetings")
|
|||
bot.load_extension("extensions.presentation")
|
||||
bot.load_extension("extensions.rorec")
|
||||
bot.load_extension("extensions.warn")
|
||||
bot.load_extension("extensions.pcp")
|
||||
|
|
162
extensions/pcp.py
Normal file
162
extensions/pcp.py
Normal file
|
@ -0,0 +1,162 @@
|
|||
import re
|
||||
|
||||
from discord import Embed
|
||||
from discord.ext import commands
|
||||
from discord.ext.commands import BadArgument
|
||||
|
||||
from administrator.logger import logger
|
||||
|
||||
|
||||
extension_name = "PCP"
|
||||
logger = logger.getChild(extension_name)
|
||||
group_re = re.compile(r"(G[0-9]S[0-9]|ASPE|LP DEVOPS|LP ESSIR|LP SID)")
|
||||
|
||||
|
||||
class PCP(commands.Cog):
|
||||
def __init__(self, bot: commands.Bot):
|
||||
self.bot = bot
|
||||
self.polls = {}
|
||||
|
||||
def description(self):
|
||||
return "PCP Univ Lyon 1"
|
||||
|
||||
@commands.group("pcp", pass_context=True)
|
||||
@commands.guild_only()
|
||||
async def pcp(self, ctx: commands.Context):
|
||||
group = ctx.message.content.replace(f"{ctx.prefix}{ctx.command} ", "").upper()
|
||||
if group and group_re.fullmatch(group):
|
||||
role = next(filter(lambda r: r.name.upper() == group, ctx.guild.roles), None)
|
||||
|
||||
if not role:
|
||||
raise BadArgument()
|
||||
|
||||
roles = list(filter(lambda r: group_re.fullmatch(r.name.upper()), ctx.author.roles))
|
||||
if role.name in map(lambda r: r.name, roles):
|
||||
raise BadArgument()
|
||||
elif roles:
|
||||
await ctx.author.remove_roles(*roles)
|
||||
|
||||
await ctx.author.add_roles(role)
|
||||
await ctx.message.add_reaction("\U0001f44d")
|
||||
return
|
||||
elif ctx.invoked_subcommand is None:
|
||||
await ctx.invoke(self.pcp_help)
|
||||
|
||||
@pcp.group("help", pass_context=True)
|
||||
@commands.guild_only()
|
||||
async def pcp_help(self, ctx: commands.Context):
|
||||
embed = Embed(title="PCP help")
|
||||
embed.add_field(name="pcp <group>", value="Join your group", inline=False)
|
||||
if await self.pcp_group.can_run(ctx):
|
||||
embed.add_field(name="pcp group", value="Manage PCP group", inline=False)
|
||||
await ctx.send(embed=embed)
|
||||
|
||||
@pcp.group("group", pass_context=True)
|
||||
@commands.has_permissions(administrator=True)
|
||||
async def pcp_group(self, ctx: commands.Context):
|
||||
if ctx.invoked_subcommand is None:
|
||||
await ctx.invoke(self.pcp_group_help)
|
||||
|
||||
@pcp_group.group("help", pass_context=True)
|
||||
async def pcp_group_help(self, ctx: commands.Context):
|
||||
embed = Embed(title="PCP group help")
|
||||
embed.add_field(name="pcp group subject", value="Manage subjects for group", inline=False)
|
||||
await ctx.send(embed=embed)
|
||||
|
||||
@pcp_group.group("subject", pass_context=True)
|
||||
async def pcp_group_subject(self, ctx: commands.Context):
|
||||
if ctx.invoked_subcommand is None:
|
||||
await ctx.invoke(self.pcp_group_subject_help)
|
||||
|
||||
@pcp_group_subject.group("help", pass_context=True)
|
||||
async def pcp_group_subject_help(self, ctx: commands.Context):
|
||||
embed = Embed(title="PCP group subject help")
|
||||
embed.add_field(name="pcp group subject add <name> <@group> [@teacher]", value="Add a subject to a group",
|
||||
inline=False)
|
||||
embed.add_field(name="pcp group subject remove <name> <@group>", value="Remove a subject to a group",
|
||||
inline=False)
|
||||
await ctx.send(embed=embed)
|
||||
|
||||
@pcp_group_subject.group("add", pass_context=True)
|
||||
async def pcp_group_subject_add(self, ctx: commands.Context, name: str):
|
||||
if len(ctx.message.role_mentions) != 1:
|
||||
raise BadArgument()
|
||||
if len(ctx.message.mentions) > 1:
|
||||
raise BadArgument()
|
||||
elif ctx.message.mentions and\
|
||||
not next(filter(lambda r: r.name == "professeurs", ctx.message.mentions[0].roles), None):
|
||||
raise BadArgument()
|
||||
|
||||
cat = next(filter(lambda c: c.name.upper() == ctx.message.role_mentions[0].name.upper(), ctx.guild.categories), None)
|
||||
if not cat:
|
||||
raise BadArgument()
|
||||
|
||||
chan = next(filter(lambda c: c.name.upper() == name.upper(), cat.text_channels), None)
|
||||
if not chan:
|
||||
chan = await cat.create_text_channel(name)
|
||||
voc = next(filter(lambda c: c.name == "vocal-1", cat.voice_channels), None)
|
||||
if not voc:
|
||||
voc = await cat.create_voice_channel("vocal-1")
|
||||
if ctx.message.mentions:
|
||||
await chan.set_permissions(ctx.message.mentions[0], read_messages=True)
|
||||
await voc.set_permissions(ctx.message.mentions[0], view_channel=True)
|
||||
|
||||
await ctx.message.add_reaction("\U0001f44d")
|
||||
|
||||
@pcp_group_subject.group("bulk", pass_context=True)
|
||||
async def pcp_group_subject_bulk(self, ctx: commands.Context, mention, *names):
|
||||
for n in names:
|
||||
await ctx.invoke(self.pcp_group_subject_add, n)
|
||||
|
||||
@pcp_group_subject.group("remove", pass_context=True)
|
||||
async def pcp_group_subject_remove(self, ctx: commands.Context, name: str):
|
||||
if len(ctx.message.role_mentions) != 1:
|
||||
raise BadArgument()
|
||||
|
||||
cat = next(filter(lambda c: c.name.upper() == ctx.message.role_mentions[0].name.upper(), ctx.guild.categories), None)
|
||||
if not cat:
|
||||
raise BadArgument()
|
||||
|
||||
chan = next(filter(lambda c: c.name.upper() == name.upper(), cat.text_channels), None)
|
||||
if not cat:
|
||||
raise BadArgument()
|
||||
|
||||
await chan.delete()
|
||||
|
||||
await ctx.message.add_reaction("\U0001f44d")
|
||||
|
||||
@pcp.group("eval", pass_context=True)
|
||||
@commands.is_owner()
|
||||
async def eval(self, ctx: commands.Context):
|
||||
start = ctx.message.content.find("```")
|
||||
end = ctx.message.content.find("```", start+3)
|
||||
command = ctx.message.content[start+3:end]
|
||||
try:
|
||||
exec("async def __ex(self, ctx):\n" + command.replace("\n", "\n "))
|
||||
await locals()["__ex"](self, ctx)
|
||||
except Exception as e:
|
||||
await ctx.send(f"{e.__class__.__name__}: {e}")
|
||||
|
||||
@pcp.group("test", pass_context=True)
|
||||
async def test(self, ctx: commands.Context):
|
||||
await ctx.message.add_reaction("\U0001f44d")
|
||||
|
||||
|
||||
def setup(bot):
|
||||
logger.info(f"Loading...")
|
||||
try:
|
||||
bot.add_cog(PCP(bot))
|
||||
except Exception as e:
|
||||
logger.error(f"Error loading: {e}")
|
||||
else:
|
||||
logger.info(f"Load successful")
|
||||
|
||||
|
||||
def teardown(bot):
|
||||
logger.info(f"Unloading...")
|
||||
try:
|
||||
bot.remove_cog("PCP")
|
||||
except Exception as e:
|
||||
logger.error(f"Error unloading: {e}")
|
||||
else:
|
||||
logger.info(f"Unload successful")
|
Reference in a new issue