approve/revoke/addhacker/removehacker/probate/unprobate: Re-make and

combine commands
This commit is contained in:
Ave Ozkal 2018-12-23 22:59:42 +03:00
parent 5fc612710c
commit 8c32a99f3d
No known key found for this signature in database
GPG key ID: 09356ABAA42C842B
6 changed files with 69 additions and 32 deletions

View file

@ -24,7 +24,8 @@ Based on https://gitlab.com/ao/dpybotbase
- [x] Moderation: kick - [x] Moderation: kick
- [x] Moderation: userinfo - [x] Moderation: userinfo
- [x] Moderation: approve-revoke (community) - [x] Moderation: approve-revoke (community)
- [ ] Moderation: addhacker-removehacker - [x] Moderation: addhacker-removehacker (hacker)
- [x] Moderation: probate-unprobate (participant)
- [ ] Moderation: lock-soft-unlock (channel lockdown) - [ ] Moderation: lock-soft-unlock (channel lockdown)
- [ ] Moderation: timelock (channel lockdown with time) - [ ] Moderation: timelock (channel lockdown with time)
- [ ] Moderation: mute-unmute - [ ] Moderation: mute-unmute
@ -33,7 +34,6 @@ Based on https://gitlab.com/ao/dpybotbase
- [x] Moderation: botnickname - [x] Moderation: botnickname
- [x] Moderation: nickname - [x] Moderation: nickname
- [ ] Moderation: clear/purge - [ ] Moderation: clear/purge
- [ ] Moderation: probate-unprobate
- [ ] Moderation: watch-unwatch (using log module from akbbot) - [ ] Moderation: watch-unwatch (using log module from akbbot)
- [ ] Warns: warn - [ ] Warns: warn
- [ ] Warns: delwarnid-delwarn - [ ] Warns: delwarnid-delwarn

View file

@ -40,8 +40,10 @@ def get_prefix(bot, message):
initial_extensions = ['cogs.common', initial_extensions = ['cogs.common',
'cogs.admin', 'cogs.admin',
'cogs.basic', 'cogs.basic',
"cogs.err", 'cogs.err',
"cogs.verification", 'cogs.verification',
'cogs.logs',
'cogs.legacy',
'cogs.links', 'cogs.links',
'cogs.mod', 'cogs.mod',
'cogs.meme'] 'cogs.meme']

22
cogs/legacy.py Normal file
View file

@ -0,0 +1,22 @@
from discord.ext import commands
class Legacy:
def __init__(self, bot):
self.bot = bot
@commands.command(hidden=True, aliases=["removehacker"])
async def probate(self, ctx):
"""Use .revoke <user> <role>"""
await ctx.send("This command was replaced with `.revoke <user> <role>`"
" on Robocop-NG, please use that instead.")
@commands.command(hidden=True, aliases=["addhacker"])
async def unprobate(self, ctx):
"""Use .approve <user> <role>"""
await ctx.send("This command was replaced with `.approve <user> <role>`"
" on Robocop-NG, please use that instead.")
def setup(bot):
bot.add_cog(Legacy(bot))

View file

@ -1,7 +1,7 @@
import discord import discord
import asyncio import asyncio
from discord.ext import commands from discord.ext import commands
from config import log_channel, staff_role_ids, participant_role, community_channels, general_channels, hacker_role, community_role from config import log_channel, staff_role_ids, named_roles, community_channels, general_channels
class Lockdown: class Lockdown:
@ -16,9 +16,9 @@ class Lockdown:
"""Locks the channel""" """Locks the channel"""
log_chan = self.bot.get_channel(log_channel) log_chan = self.bot.get_channel(log_channel)
if ctx.message.channel in community_channels: if ctx.message.channel in community_channels:
roles = (hacker_role, community_role) roles = (named_roles["hacker"], named_roles["community"])
else: else:
roles = participant_role roles = named_roles["participant"]
overwrites = ctx.message.channel.overwrites_for(roles[0]) overwrites = ctx.message.channel.overwrites_for(roles[0])
if not overwrites.send_message: if not overwrites.send_message:
await ctx.send("This channel is already locked!") await ctx.send("This channel is already locked!")

View file

@ -141,38 +141,46 @@ class ModCog:
@commands.guild_only() @commands.guild_only()
@commands.check(check_if_staff) @commands.check(check_if_staff)
@commands.command() @commands.command()
async def approve(self, ctx): async def approve(self, ctx, target: discord.Member,
approval_list = ctx.message.mentions role: str = "community"):
community_role = ctx.guild.get_role(config.community_role) if role not in config.named_roles:
for to_approve in approval_list: return await ctx.send("No such role! Available roles: " +
await to_approve.add_roles(community_role, ','.join(config.named_roles))
reason=str(ctx.author))
await ctx.send(f"Approved {len(approval_list)} member(s).")
log_channel = self.bot.get_channel(config.log_channel) log_channel = self.bot.get_channel(config.log_channel)
target_role = ctx.guild.get_role(config.named_roles[role])
approved_mentions = [approved.mention for approved in approval_list] if target_role in target.roles:
await log_channel.send(f"✅ Approved: {ctx.author.mention} approved" return await ctx.send("Target already has this role.")
f" {len(approval_list)} members\n"
f"{' '.join(approved_mentions)}") # HACK await target.add_roles(target_role, reason=str(ctx.author))
await ctx.send(f"Approved {target.mention} to role {role}.")
await log_channel.send(f"✅ Approved: {ctx.author.mention} added"
f" {role} to {target.mention}")
@commands.guild_only() @commands.guild_only()
@commands.check(check_if_staff) @commands.check(check_if_staff)
@commands.command(aliases=["unapprove"]) @commands.command(aliases=["unapprove"])
async def revoke(self, ctx): async def revoke(self, ctx, target: discord.Member,
revoke_list = ctx.message.mentions role: str = "community"):
community_role = ctx.guild.get_role(config.community_role) if role not in config.named_roles:
for to_revoke in revoke_list: return await ctx.send("No such role! Available roles: " +
await to_revoke.remove_roles(community_role, ','.join(config.named_roles))
reason=str(ctx.author))
await ctx.send(f"Un-approved {len(revoke_list)} member(s).")
log_channel = self.bot.get_channel(config.log_channel) log_channel = self.bot.get_channel(config.log_channel)
target_role = ctx.guild.get_role(config.named_roles[role])
revoked_mentions = [revoked.mention for revoked in revoke_list] if target_role not in target.roles:
await log_channel.send(f"❌ Un-approved: {ctx.author.mention} approved" return await ctx.send("Target doesn't have this role.")
f" {len(revoke_list)} members\n"
f"{' '.join(revoked_mentions)}") # HACK await target.remove_roles(target_role, reason=str(ctx.author))
await ctx.send(f"Un-approved {target.mention} from role {role}.")
await log_channel.send(f"❌ Un-approved: {ctx.author.mention} removed"
f" {role} from {target.mention}")
@commands.guild_only() @commands.guild_only()
@commands.check(check_if_staff) @commands.check(check_if_staff)

View file

@ -22,6 +22,14 @@ guild_whitelist = [
269333940928512010 # ReSwitched discord 269333940928512010 # ReSwitched discord
] ]
# Named roles to be used with .approve and .revoke
# The defaults are for NotSwitched
named_roles = {
"community": 526378381839695872,
"hacker": 526471781184176139,
"participant": 526378358129557506
}
bot_manager_role_id = 526372554081042462 # Bot management role in NotSwitched bot_manager_role_id = 526372554081042462 # Bot management role in NotSwitched
staff_role_ids = [526384077679624192, # Team role in NotSwitched staff_role_ids = [526384077679624192, # Team role in NotSwitched
526372582455508992, # Mod role in NotSwitched 526372582455508992, # Mod role in NotSwitched
@ -30,9 +38,6 @@ staff_role_ids = [526384077679624192, # Team role in NotSwitched
log_channel = 526377735908491284 # Log channel in NotSwitched log_channel = 526377735908491284 # Log channel in NotSwitched
welcome_channel = 526372470752673792 # rules-info channel in NotSwitched welcome_channel = 526372470752673792 # rules-info channel in NotSwitched
participant_role = 526378358129557506 # participant role in NotSwitched
community_role = 526378381839695872 # community role in NotSwitched
hacker_role = 526471781184176139 # hacker role in NotSwitched
community_channels = [526378423468425236] # Channels requiring community role community_channels = [526378423468425236] # Channels requiring community role
general_channels = [526372255052201995] # Channels everyone can access general_channels = [526372255052201995] # Channels everyone can access