Restrictions: Significantly clean up code

This commit is contained in:
Ave Ozkal 2018-12-27 14:56:13 +03:00
parent 5521b4aa58
commit 77f43caca9
No known key found for this signature in database
GPG key ID: 09356ABAA42C842B
3 changed files with 42 additions and 28 deletions

View file

@ -1,6 +1,7 @@
import discord import discord
import json import json
import config import config
from helpers.restrictions import get_user_restrictions
class Logs: class Logs:
@ -43,15 +44,11 @@ class Logs:
f"🕓 Account age: {age}\n"\ f"🕓 Account age: {age}\n"\
f"🏷 __User ID__: {member.id}" f"🏷 __User ID__: {member.id}"
# Taken from kurisu source. # Handles user restrictions
# Blame ihaveamac, not me. # Basically, gives back muted role to users that leave with it.
with open("data/restrictions.json", "r") as f: rsts = get_user_restrictions(member.id)
rsts = json.load(f) roles = [discord.utils.get(member.guild.roles, id=rst) for rst in rsts]
if str(member.id) in rsts: await member.add_roles(*roles)
roles = []
for rst in rsts[str(member.id)]:
roles.append(discord.utils.get(member.guild.roles, id=rst))
await member.add_roles(*roles)
# Real hell zone. # Real hell zone.
with open("data/userlog.json", "r") as f: with open("data/userlog.json", "r") as f:

View file

@ -57,7 +57,7 @@ class Mod:
log_channel = self.bot.get_channel(config.log_channel) log_channel = self.bot.get_channel(config.log_channel)
await log_channel.send(chan_message) await log_channel.send(chan_message)
await ctx.send(f"{target.mention} can no longer speak.") await ctx.send(f"{target.mention} can no longer speak.")
await add_restriction(target, config.mute_role) add_restriction(target.id, config.mute_role)
@commands.guild_only() @commands.guild_only()
@commands.check(check_if_staff) @commands.check(check_if_staff)
@ -76,7 +76,7 @@ class Mod:
log_channel = self.bot.get_channel(config.log_channel) log_channel = self.bot.get_channel(config.log_channel)
await log_channel.send(chan_message) await log_channel.send(chan_message)
await ctx.send(f"{target.mention} can now speak again.") await ctx.send(f"{target.mention} can now speak again.")
await remove_restriction(target, config.mute_role) remove_restriction(target.id, config.mute_role)
@commands.guild_only() @commands.guild_only()
@commands.bot_has_permissions(kick_members=True) @commands.bot_has_permissions(kick_members=True)

View file

@ -1,25 +1,42 @@
import json import json
def add_restriction(self, member, rst): def get_restrictions():
# from kurisu source, credits go to ihaveamac
with open("data/restrictions.json", "r") as f: with open("data/restrictions.json", "r") as f:
rsts = json.load(f) return json.load(f)
if str(member.id) not in rsts:
rsts[str(member.id)] = []
if rst not in rsts[str(member.id)]:
rsts[str(member.id)].append(rst)
with open("data/restrictions.json", "w") as f:
json.dump(rsts, f)
def remove_restriction(self, member, rst): def set_restrictions(contents):
# from kurisu source, credits go to ihaveamac with open("data/restrictions.json", "w") as f:
f.write(contents)
def get_user_restrictions(uid):
uid = str(uid)
with open("data/restrictions.json", "r") as f: with open("data/restrictions.json", "r") as f:
rsts = json.load(f) rsts = json.load(f)
if str(member.id) not in rsts: if uid in rsts:
rsts[str(member.id)] = [] return rsts[uid]
if rst in rsts[str(member.id)]: return []
rsts[str(member.id)].remove(rst)
with open("data/restrictions.json", "w") as f:
json.dump(rsts, f) def add_restriction(uid, rst):
# mostly from kurisu source, credits go to ihaveamac
uid = str(uid)
rsts = get_restrictions()
if uid not in rsts:
rsts[uid] = []
if rst not in rsts[uid]:
rsts[uid].append(rst)
set_restrictions(json.dumps(rsts))
def remove_restriction(uid, rst):
# mostly from kurisu source, credits go to ihaveamac
uid = str(uid)
rsts = get_restrictions()
if uid not in rsts:
rsts[uid] = []
if rst in rsts[uid]:
rsts[uid].remove(rst)
set_restrictions(json.dumps(rsts))