mirror of
https://github.com/AsgardEternal/DiscordWhitelist.git
synced 2025-01-21 11:33:47 -06:00
Compare commits
3 Commits
1747e55549
...
d90dc43d47
Author | SHA1 | Date | |
---|---|---|---|
d90dc43d47 | |||
323344aa2f | |||
3bea54be88 |
@ -18,29 +18,36 @@ class Group(commands.Cog, name="group"):
|
|||||||
def __init__(self, client: Bot):
|
def __init__(self, client: Bot):
|
||||||
self.client = client
|
self.client = client
|
||||||
|
|
||||||
async def updateRole(self, role:discord.Role):
|
async def updateRole(self, role: discord.Role):
|
||||||
self.client.squadjs.connect()
|
self.client.squadjs.connect()
|
||||||
membsup = []
|
membsup = []
|
||||||
for memb in role.members:
|
for memb in role.members:
|
||||||
membsup.append(memb.id)
|
membsup.append(memb.id)
|
||||||
if len(membsup) > 0:
|
if len(membsup) > 0:
|
||||||
memupcur = self.client.squadjs.cursor(buffered=True)
|
memupcur = self.client.squadjs.cursor(buffered=True)
|
||||||
in_params = ','.join(['%s'] * len(membsup))
|
in_params = ",".join(["%s"] * len(membsup))
|
||||||
sqlstate = "SELECT * FROM DBLog_SteamUsers WHERE discordID IN (%s)" % in_params
|
sqlstate = (
|
||||||
|
"SELECT * FROM DBLog_SteamUsers WHERE discordID IN (%s)" % in_params
|
||||||
|
)
|
||||||
log.info(sqlstate)
|
log.info(sqlstate)
|
||||||
memupcur.execute(sqlstate, membsup)
|
memupcur.execute(sqlstate, membsup)
|
||||||
|
|
||||||
udata = memupcur.fetchall()
|
udata = memupcur.fetchall()
|
||||||
for data in udata:
|
for data in udata:
|
||||||
self.client.whitelistGrps[role.id].addMember(config.WhitelistMember(data[2], data[1], data[0]))
|
self.client.whitelistGrps[role.id].addMember(
|
||||||
|
config.WhitelistMember(data[2], data[1], data[0])
|
||||||
|
)
|
||||||
|
|
||||||
self.client.squadjs.commit()
|
self.client.squadjs.commit()
|
||||||
self.client.squadjs.close()
|
self.client.squadjs.close()
|
||||||
|
|
||||||
|
async def baseperm(
|
||||||
|
self, interaction: discord.Interaction, role: discord.Role, perms: str
|
||||||
|
):
|
||||||
|
|
||||||
async def baseperm(self, interaction: discord.Interaction, role: discord.Role, perms: str):
|
await interaction.response.send_message(
|
||||||
|
"Whitelist group successfully added/updated"
|
||||||
await interaction.response.send_message("Whitelist group successfully added/updated")
|
)
|
||||||
if role.id in self.client.whitelistGrps.keys():
|
if role.id in self.client.whitelistGrps.keys():
|
||||||
if perms is not None:
|
if perms is not None:
|
||||||
self.client.whitelistGrps[role.id].squadPerms = perms
|
self.client.whitelistGrps[role.id].squadPerms = perms
|
||||||
@ -54,11 +61,7 @@ class Group(commands.Cog, name="group"):
|
|||||||
await self.updateRole(role)
|
await self.updateRole(role)
|
||||||
|
|
||||||
@app_commands.command()
|
@app_commands.command()
|
||||||
async def update(
|
async def update(self, interaction: discord.Interaction, role: discord.Role):
|
||||||
self,
|
|
||||||
interaction: discord.Interaction,
|
|
||||||
role: discord.Role
|
|
||||||
):
|
|
||||||
if role.id in self.client.whitelistGrps.keys():
|
if role.id in self.client.whitelistGrps.keys():
|
||||||
await interaction.response.send_message("updating role!")
|
await interaction.response.send_message("updating role!")
|
||||||
await self.updateRole(role)
|
await self.updateRole(role)
|
||||||
@ -75,10 +78,7 @@ class Group(commands.Cog, name="group"):
|
|||||||
|
|
||||||
@app_commands.command()
|
@app_commands.command()
|
||||||
async def addperm(
|
async def addperm(
|
||||||
self,
|
self, interaction: discord.Interaction, role: discord.Role, perms: str
|
||||||
interaction: discord.Interaction,
|
|
||||||
role: discord.Role,
|
|
||||||
perms: str
|
|
||||||
):
|
):
|
||||||
await self.baseperm(interaction, role, perms)
|
await self.baseperm(interaction, role, perms)
|
||||||
|
|
||||||
@ -88,7 +88,7 @@ class Group(commands.Cog, name="group"):
|
|||||||
interaction: discord.Interaction,
|
interaction: discord.Interaction,
|
||||||
shortname: str,
|
shortname: str,
|
||||||
remoteurl: str,
|
remoteurl: str,
|
||||||
perms: str = 'whitelist'
|
perms: str = "whitelist",
|
||||||
):
|
):
|
||||||
if os.path.exists(f"wlgrps/{shortname}.cfg"):
|
if os.path.exists(f"wlgrps/{shortname}.cfg"):
|
||||||
await interaction.response.send_message("Already exists!")
|
await interaction.response.send_message("Already exists!")
|
||||||
|
@ -26,28 +26,46 @@ class Whitelist(commands.Cog):
|
|||||||
return
|
return
|
||||||
updatecur = self.client.squadjs.cursor(buffered=True)
|
updatecur = self.client.squadjs.cursor(buffered=True)
|
||||||
try:
|
try:
|
||||||
updatecur.execute(self.client.squadjs_updateDiscordID, (interaction.user.id, steam64))
|
updatecur.execute(
|
||||||
|
self.client.squadjs_updateDiscordID, (interaction.user.id, steam64)
|
||||||
|
)
|
||||||
rowsaffected = updatecur.rowcount
|
rowsaffected = updatecur.rowcount
|
||||||
if rowsaffected <= 0:
|
if rowsaffected <= 0:
|
||||||
updatecur.execute(self.client.squadjs_findByDiscordID, [interaction.user.id])
|
updatecur.execute(
|
||||||
|
self.client.squadjs_findByDiscordID, [interaction.user.id]
|
||||||
|
)
|
||||||
if updatecur.rowcount <= 0:
|
if updatecur.rowcount <= 0:
|
||||||
await interaction.response.send_message("Cound not find SteamID!")
|
await interaction.response.send_message("Cound not find SteamID!")
|
||||||
else:
|
else:
|
||||||
for urole in interaction.user.roles:
|
for urole in interaction.user.roles:
|
||||||
if urole.id in self.client.whitelistGrps.keys():
|
if urole.id in self.client.whitelistGrps.keys():
|
||||||
self.client.whitelistGrps[urole.id].members[f"{interaction.user.id}"].steam64 = steam64
|
self.client.whitelistGrps[urole.id].members[
|
||||||
|
f"{interaction.user.id}"
|
||||||
|
].steam64 = steam64
|
||||||
self.client.whitelistGrps[urole.id].updateGroup()
|
self.client.whitelistGrps[urole.id].updateGroup()
|
||||||
await interaction.response.send_message("SteamID already linked, roles updated.")
|
await interaction.response.send_message(
|
||||||
|
"SteamID already linked, roles updated."
|
||||||
|
)
|
||||||
self.client.squadjs.commit()
|
self.client.squadjs.commit()
|
||||||
return
|
return
|
||||||
except mysql.connector.Error as err:
|
except mysql.connector.Error as err:
|
||||||
log.error("MYSQL error!")
|
log.error("MYSQL error!")
|
||||||
await interaction.response.send_message("There was an internal server error, pls contact skillet")
|
await interaction.response.send_message(
|
||||||
|
"There was an internal server error, pls contact skillet"
|
||||||
|
)
|
||||||
return
|
return
|
||||||
for urole in interaction.user.roles:
|
for urole in interaction.user.roles:
|
||||||
if urole.id in self.client.whitelistGrps.keys():
|
if urole.id in self.client.whitelistGrps.keys():
|
||||||
disusername = interaction.user.nick if interaction.user.nick is not None else interaction.user.name
|
disusername = (
|
||||||
self.client.whitelistGrps[urole.id].addMember(config.WhitelistMember(interaction.user.id, disusername, steam64))
|
interaction.user.nick
|
||||||
|
if interaction.user.nick is not None
|
||||||
|
else interaction.user.name
|
||||||
|
)
|
||||||
|
self.client.whitelistGrps[urole.id].addMember(
|
||||||
|
config.WhitelistMember(interaction.user.id, disusername, steam64)
|
||||||
|
)
|
||||||
self.client.squadjs.commit()
|
self.client.squadjs.commit()
|
||||||
self.client.squadjs.close()
|
self.client.squadjs.close()
|
||||||
await interaction.response.send_message(f"discord is linked to steamID, roles updated.")
|
await interaction.response.send_message(
|
||||||
|
f"discord is linked to steamID, roles updated."
|
||||||
|
)
|
||||||
|
@ -6,6 +6,7 @@ from autowl.config import DiscordClientConfig
|
|||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class CustomFormat(logging.Formatter):
|
class CustomFormat(logging.Formatter):
|
||||||
grey = "\x1b[38;20m"
|
grey = "\x1b[38;20m"
|
||||||
yellow = "\x1b[33;20m"
|
yellow = "\x1b[33;20m"
|
||||||
|
@ -11,21 +11,21 @@ log = logging.getLogger(__name__)
|
|||||||
|
|
||||||
|
|
||||||
class Bot(commands.Bot):
|
class Bot(commands.Bot):
|
||||||
squadjs_updateDiscordID = ("UPDATE DBLog_SteamUsers SET discordID = %s "
|
squadjs_updateDiscordID = (
|
||||||
"WHERE steamID = %s")
|
"UPDATE DBLog_SteamUsers SET discordID = %s " "WHERE steamID = %s"
|
||||||
|
)
|
||||||
|
|
||||||
squadjs_findByDiscordID = ("SELECT * FROM DBLog_SteamUsers "
|
squadjs_findByDiscordID = "SELECT * FROM DBLog_SteamUsers " "WHERE discordID = %s"
|
||||||
"WHERE discordID = %s")
|
|
||||||
|
|
||||||
whitelistGrps = {}
|
whitelistGrps = {}
|
||||||
|
|
||||||
if not os.path.exists('./wlgrps'):
|
if not os.path.exists("./wlgrps"):
|
||||||
os.makedirs('./wlgrps')
|
os.makedirs("./wlgrps")
|
||||||
else:
|
else:
|
||||||
for wlfile in os.listdir('./wlgrps'):
|
for wlfile in os.listdir("./wlgrps"):
|
||||||
filename = os.fsdecode(wlfile)
|
filename = os.fsdecode(wlfile)
|
||||||
if filename.endswith('.json'):
|
if filename.endswith(".json"):
|
||||||
file = open(f'./wlgrps/{filename}', 'r')
|
file = open(f"./wlgrps/{filename}", "r")
|
||||||
wlgrp: config.WhitelistGroup = jsonpickle.decode(file.read())
|
wlgrp: config.WhitelistGroup = jsonpickle.decode(file.read())
|
||||||
whitelistGrps[wlgrp.discord_role_id] = wlgrp
|
whitelistGrps[wlgrp.discord_role_id] = wlgrp
|
||||||
|
|
||||||
@ -39,11 +39,18 @@ class Bot(commands.Bot):
|
|||||||
intents=intents,
|
intents=intents,
|
||||||
help_command=commands.DefaultHelpCommand(dm_help=True),
|
help_command=commands.DefaultHelpCommand(dm_help=True),
|
||||||
)
|
)
|
||||||
self.squadjs = mysql.connector.connect(user='squadjs', password=mysqlpass,
|
self.squadjs = mysql.connector.connect(
|
||||||
host='asgard.orion-technologies.io', database='squadjs', use_pure=False)
|
user="squadjs",
|
||||||
|
password=mysqlpass,
|
||||||
|
host="asgard.orion-technologies.io",
|
||||||
|
database="squadjs",
|
||||||
|
use_pure=False,
|
||||||
|
)
|
||||||
|
|
||||||
async def on_command(self, ctx: commands.Context):
|
async def on_command(self, ctx: commands.Context):
|
||||||
log.info(f"{ctx.author} ({ctx.author.id}) invoked command: {ctx.command.name}, {ctx.message}")
|
log.info(
|
||||||
|
f"{ctx.author} ({ctx.author.id}) invoked command: {ctx.command.name}, {ctx.message}"
|
||||||
|
)
|
||||||
|
|
||||||
async def on_ready(self):
|
async def on_ready(self):
|
||||||
log.info(f"Logged in as '{self.user}' ({self.user.id})")
|
log.info(f"Logged in as '{self.user}' ({self.user.id})")
|
||||||
@ -59,6 +66,27 @@ class Bot(commands.Bot):
|
|||||||
|
|
||||||
await self.tree.sync()
|
await self.tree.sync()
|
||||||
|
|
||||||
|
# HACK: Ensure correct members are synced to their groups when bot is started
|
||||||
|
for guild in self.guilds:
|
||||||
|
for wlgrp in self.whitelistGrps.values():
|
||||||
|
if role := guild.get_role(wlgrp.discord_role_id):
|
||||||
|
role_member_ids = set([member.id for member in role.members])
|
||||||
|
wlgrp_member_ids = set(
|
||||||
|
[
|
||||||
|
wlgrp_member.discord_id
|
||||||
|
for wlgrp_member in wlgrp.members.values()
|
||||||
|
]
|
||||||
|
)
|
||||||
|
log.info(
|
||||||
|
f"Checking group membership for {role.name} ({role.id}) on startup"
|
||||||
|
)
|
||||||
|
members_to_remove = wlgrp_member_ids - role_member_ids
|
||||||
|
for member_id in members_to_remove:
|
||||||
|
log.info(
|
||||||
|
f"Removing {member_id} from {role.id} role group"
|
||||||
|
)
|
||||||
|
wlgrp.delMember(member_id)
|
||||||
|
|
||||||
async def on_member_update(self, before: discord.Member, after: discord.Member):
|
async def on_member_update(self, before: discord.Member, after: discord.Member):
|
||||||
disusername = after.nick if after.nick is not None else after.name
|
disusername = after.nick if after.nick is not None else after.name
|
||||||
self.squadjs.connect()
|
self.squadjs.connect()
|
||||||
@ -77,7 +105,7 @@ class Bot(commands.Bot):
|
|||||||
rmroles.remove(aftrole.id)
|
rmroles.remove(aftrole.id)
|
||||||
log.info(f"roles found to remove from {disusername}: {rmroles}")
|
log.info(f"roles found to remove from {disusername}: {rmroles}")
|
||||||
for rmroleid in rmroles:
|
for rmroleid in rmroles:
|
||||||
if not(rmroleid in self.whitelistGrps.keys()):
|
if not (rmroleid in self.whitelistGrps.keys()):
|
||||||
continue
|
continue
|
||||||
self.whitelistGrps[rmroleid].delMember(before.id)
|
self.whitelistGrps[rmroleid].delMember(before.id)
|
||||||
|
|
||||||
@ -90,9 +118,11 @@ class Bot(commands.Bot):
|
|||||||
addroles.remove(befrole.id)
|
addroles.remove(befrole.id)
|
||||||
log.info(f"roles found to add to {disusername}: {addroles}")
|
log.info(f"roles found to add to {disusername}: {addroles}")
|
||||||
for addroleid in addroles:
|
for addroleid in addroles:
|
||||||
if not(addroleid in self.whitelistGrps.keys()):
|
if not (addroleid in self.whitelistGrps.keys()):
|
||||||
continue
|
continue
|
||||||
self.whitelistGrps[addroleid].addMember(config.WhitelistMember(after.id, disusername, userdata[0]))
|
self.whitelistGrps[addroleid].addMember(
|
||||||
|
config.WhitelistMember(after.id, disusername, userdata[0])
|
||||||
|
)
|
||||||
self.squadjs.commit()
|
self.squadjs.commit()
|
||||||
self.squadjs.close()
|
self.squadjs.close()
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ class WhitelistGroup:
|
|||||||
squadPerms: str
|
squadPerms: str
|
||||||
members: dict[str, WhitelistMember]
|
members: dict[str, WhitelistMember]
|
||||||
|
|
||||||
def __init__(self, name, roleID, permissions='reserve'):
|
def __init__(self, name, roleID, permissions="reserve"):
|
||||||
self.name = name
|
self.name = name
|
||||||
self.discord_role_id = roleID
|
self.discord_role_id = roleID
|
||||||
self.squadPerms = permissions
|
self.squadPerms = permissions
|
||||||
@ -49,7 +49,9 @@ class WhitelistGroup:
|
|||||||
wlFile.write(f"//{self.name}\n")
|
wlFile.write(f"//{self.name}\n")
|
||||||
for wlmem in self.members:
|
for wlmem in self.members:
|
||||||
memb = self.members[wlmem]
|
memb = self.members[wlmem]
|
||||||
wlFile.write(f"Admin={memb.steam64}:{self.name} //{memb.discord_username} ({memb.discord_id})\n")
|
wlFile.write(
|
||||||
|
f"Admin={memb.steam64}:{self.name} //{memb.discord_username} ({memb.discord_id})\n"
|
||||||
|
)
|
||||||
wlFile.close()
|
wlFile.close()
|
||||||
|
|
||||||
def addMember(self, member):
|
def addMember(self, member):
|
||||||
@ -59,6 +61,6 @@ class WhitelistGroup:
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
def delMember(self, discordID):
|
def delMember(self, discordID):
|
||||||
self.members.pop(f'{discordID}')
|
self.members.pop(f"{discordID}")
|
||||||
self.updateFile()
|
self.updateFile()
|
||||||
self.updateWL()
|
self.updateWL()
|
||||||
|
999
poetry.lock
generated
999
poetry.lock
generated
File diff suppressed because it is too large
Load Diff
@ -16,11 +16,11 @@ PORT = 8000
|
|||||||
class serveRA(http.server.SimpleHTTPRequestHandler):
|
class serveRA(http.server.SimpleHTTPRequestHandler):
|
||||||
def do_GET(self):
|
def do_GET(self):
|
||||||
query = parse_qs(urlparse(self.path).query)
|
query = parse_qs(urlparse(self.path).query)
|
||||||
if 'grpName' in query:
|
if "grpName" in query:
|
||||||
self.send_response(200)
|
self.send_response(200)
|
||||||
self.send_header("Content-type", "text")
|
self.send_header("Content-type", "text")
|
||||||
self.end_headers()
|
self.end_headers()
|
||||||
grpName = query['grpName'][0]
|
grpName = query["grpName"][0]
|
||||||
grpfile = "./"
|
grpfile = "./"
|
||||||
if os.path.exists(f"./wlgrps/{grpName}.cfg"):
|
if os.path.exists(f"./wlgrps/{grpName}.cfg"):
|
||||||
grpfile += f"wlgrps/{grpName}.cfg"
|
grpfile += f"wlgrps/{grpName}.cfg"
|
||||||
@ -30,37 +30,53 @@ class serveRA(http.server.SimpleHTTPRequestHandler):
|
|||||||
print("could not find admins file!", file=stderr)
|
print("could not find admins file!", file=stderr)
|
||||||
return
|
return
|
||||||
try:
|
try:
|
||||||
file = open(grpfile, 'rb')
|
file = open(grpfile, "rb")
|
||||||
firstline = file.readline().decode('utf-8')
|
firstline = file.readline().decode("utf-8")
|
||||||
file.seek(0)
|
file.seek(0)
|
||||||
if firstline.startswith('remotelist='):
|
if firstline.startswith("remotelist="):
|
||||||
remote = firstline.split('=')[1].strip()
|
remote = firstline.split("=")[1].strip()
|
||||||
response = requests.get(remote, headers={'Accept': 'text/html,*/*'})
|
response = requests.get(remote, headers={"Accept": "text/html,*/*"})
|
||||||
print(f"remote list came back with status code {response.status_code}")
|
print(
|
||||||
|
f"remote list came back with status code {response.status_code}"
|
||||||
|
)
|
||||||
if response.status_code == 200:
|
if response.status_code == 200:
|
||||||
responsetext = response.text
|
responsetext = response.text
|
||||||
config = file.read().decode('utf-8')
|
config = file.read().decode("utf-8")
|
||||||
confgrps = re.findall(r"permissions/(.+)=(.+)", config, flags=re.M)
|
confgrps = re.findall(
|
||||||
|
r"permissions/(.+)=(.+)", config, flags=re.M
|
||||||
|
)
|
||||||
baseperm = re.findall(r"permissions=(.+)", config, flags=re.M)
|
baseperm = re.findall(r"permissions=(.+)", config, flags=re.M)
|
||||||
responsetext = re.sub(r"Group=(.+):(.+)", fr'Group=\1:{baseperm[0]}', responsetext, flags=re.M)
|
responsetext = re.sub(
|
||||||
|
r"Group=(.+):(.+)",
|
||||||
|
rf"Group=\1:{baseperm[0]}",
|
||||||
|
responsetext,
|
||||||
|
flags=re.M,
|
||||||
|
)
|
||||||
for congrp in confgrps:
|
for congrp in confgrps:
|
||||||
responsetext = re.sub(rf"^Group=({congrp[0]}):(.+)", rf"Group=\1:{congrp[1]}", responsetext, flags=re.M)
|
responsetext = re.sub(
|
||||||
self.wfile.write(responsetext.encode('utf-8'))
|
rf"^Group=({congrp[0]}):(.+)",
|
||||||
with open(f"./wlgrps/backup-{grpName}.cfg", 'wb') as backupfile:
|
rf"Group=\1:{congrp[1]}",
|
||||||
backupfile.write(responsetext.encode('utf-8'))
|
responsetext,
|
||||||
|
flags=re.M,
|
||||||
|
)
|
||||||
|
self.wfile.write(responsetext.encode("utf-8"))
|
||||||
|
with open(f"./wlgrps/backup-{grpName}.cfg", "wb") as backupfile:
|
||||||
|
backupfile.write(responsetext.encode("utf-8"))
|
||||||
backupfile.close()
|
backupfile.close()
|
||||||
else:
|
else:
|
||||||
backupfile = open(f"./wlgrps/backup-{grpName}.cfg", 'rb')
|
backupfile = open(f"./wlgrps/backup-{grpName}.cfg", "rb")
|
||||||
self.copyfile(backupfile, self.wfile)
|
self.copyfile(backupfile, self.wfile)
|
||||||
backupfile.close()
|
backupfile.close()
|
||||||
else:
|
else:
|
||||||
self.copyfile(file, self.wfile)
|
self.copyfile(file, self.wfile)
|
||||||
file.close()
|
file.close()
|
||||||
except:
|
except:
|
||||||
print('failed to serve file!', file=stderr)
|
print("failed to serve file!", file=stderr)
|
||||||
print(traceback.format_exc(), file=stderr)
|
print(traceback.format_exc(), file=stderr)
|
||||||
else:
|
else:
|
||||||
self.send_error(400, 'please specify the group to pull from', 'no grpName specified!')
|
self.send_error(
|
||||||
|
400, "please specify the group to pull from", "no grpName specified!"
|
||||||
|
)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
@ -71,7 +87,7 @@ def startServer():
|
|||||||
print("trying to start...")
|
print("trying to start...")
|
||||||
try:
|
try:
|
||||||
with socketserver.ThreadingTCPServer(("", PORT), handler) as httpd:
|
with socketserver.ThreadingTCPServer(("", PORT), handler) as httpd:
|
||||||
print('starting server!')
|
print("starting server!")
|
||||||
httpd.serve_forever()
|
httpd.serve_forever()
|
||||||
except:
|
except:
|
||||||
print("server did not start trying again!")
|
print("server did not start trying again!")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user