Compare commits

..

No commits in common. "d90dc43d472de6f50ed45f6e0df8e9fd8733b95a" and "1747e55549a3e7c7e019ae0630f774c1b39b78a7" have entirely different histories.

7 changed files with 506 additions and 698 deletions

View File

@ -18,36 +18,29 @@ 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 = ( sqlstate = "SELECT * FROM DBLog_SteamUsers WHERE discordID IN (%s)" % in_params
"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( self.client.whitelistGrps[role.id].addMember(config.WhitelistMember(data[2], data[1], data[0]))
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
):
await interaction.response.send_message( async def baseperm(self, interaction: discord.Interaction, role: discord.Role, perms: str):
"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
@ -61,7 +54,11 @@ class Group(commands.Cog, name="group"):
await self.updateRole(role) await self.updateRole(role)
@app_commands.command() @app_commands.command()
async def update(self, interaction: discord.Interaction, role: discord.Role): async def update(
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)
@ -70,25 +67,28 @@ class Group(commands.Cog, name="group"):
@app_commands.command() @app_commands.command()
async def add( async def add(
self, self,
interaction: discord.Interaction, interaction: discord.Interaction,
role: discord.Role, role: discord.Role,
): ):
await self.baseperm(interaction, role, "reserve") await self.baseperm(interaction, role, "reserve")
@app_commands.command() @app_commands.command()
async def addperm( async def addperm(
self, interaction: discord.Interaction, role: discord.Role, perms: str self,
interaction: discord.Interaction,
role: discord.Role,
perms: str
): ):
await self.baseperm(interaction, role, perms) await self.baseperm(interaction, role, perms)
@app_commands.command() @app_commands.command()
async def addremote( async def addremote(
self, self,
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!")
@ -102,9 +102,9 @@ class Group(commands.Cog, name="group"):
@app_commands.command() @app_commands.command()
async def remove( async def remove(
self, self,
interaction: discord.Interaction, interaction: discord.Interaction,
role: discord.Role, role: discord.Role,
): ):
if not self.client.whitelistGrps.get(role.id): if not self.client.whitelistGrps.get(role.id):
await interaction.response.send_message( await interaction.response.send_message(

View File

@ -26,46 +26,28 @@ class Whitelist(commands.Cog):
return return
updatecur = self.client.squadjs.cursor(buffered=True) updatecur = self.client.squadjs.cursor(buffered=True)
try: try:
updatecur.execute( updatecur.execute(self.client.squadjs_updateDiscordID, (interaction.user.id, steam64))
self.client.squadjs_updateDiscordID, (interaction.user.id, steam64)
)
rowsaffected = updatecur.rowcount rowsaffected = updatecur.rowcount
if rowsaffected <= 0: if rowsaffected <= 0:
updatecur.execute( updatecur.execute(self.client.squadjs_findByDiscordID, [interaction.user.id])
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[ self.client.whitelistGrps[urole.id].members[f"{interaction.user.id}"].steam64 = steam64
f"{interaction.user.id}"
].steam64 = steam64
self.client.whitelistGrps[urole.id].updateGroup() self.client.whitelistGrps[urole.id].updateGroup()
await interaction.response.send_message( await interaction.response.send_message("SteamID already linked, roles updated.")
"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( await interaction.response.send_message("There was an internal server error, pls contact skillet")
"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 = ( disusername = interaction.user.nick if interaction.user.nick is not None else interaction.user.name
interaction.user.nick self.client.whitelistGrps[urole.id].addMember(config.WhitelistMember(interaction.user.id, disusername, steam64))
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( await interaction.response.send_message(f"discord is linked to steamID, roles updated.")
f"discord is linked to steamID, roles updated."
)

View File

@ -6,7 +6,6 @@ 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"

View File

@ -11,21 +11,21 @@ log = logging.getLogger(__name__)
class Bot(commands.Bot): class Bot(commands.Bot):
squadjs_updateDiscordID = ( squadjs_updateDiscordID = ("UPDATE DBLog_SteamUsers SET discordID = %s "
"UPDATE DBLog_SteamUsers SET discordID = %s " "WHERE steamID = %s" "WHERE steamID = %s")
)
squadjs_findByDiscordID = "SELECT * FROM DBLog_SteamUsers " "WHERE discordID = %s" squadjs_findByDiscordID = ("SELECT * FROM DBLog_SteamUsers "
"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,18 +39,11 @@ 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( self.squadjs = mysql.connector.connect(user='squadjs', password=mysqlpass,
user="squadjs", host='asgard.orion-technologies.io', database='squadjs', use_pure=False)
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( log.info(f"{ctx.author} ({ctx.author.id}) invoked command: {ctx.command.name}, {ctx.message}")
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})")
@ -66,27 +59,6 @@ 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()
@ -105,7 +77,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)
@ -118,11 +90,9 @@ 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( self.whitelistGrps[addroleid].addMember(config.WhitelistMember(after.id, disusername, userdata[0]))
config.WhitelistMember(after.id, disusername, userdata[0])
)
self.squadjs.commit() self.squadjs.commit()
self.squadjs.close() self.squadjs.close()

View File

@ -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,9 +49,7 @@ 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( wlFile.write(f"Admin={memb.steam64}:{self.name} //{memb.discord_username} ({memb.discord_id})\n")
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):
@ -61,6 +59,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()

993
poetry.lock generated

File diff suppressed because it is too large Load Diff

View File

@ -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,53 +30,37 @@ 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( print(f"remote list came back with status code {response.status_code}")
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( confgrps = re.findall(r"permissions/(.+)=(.+)", config, flags=re.M)
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( responsetext = re.sub(r"Group=(.+):(.+)", fr'Group=\1:{baseperm[0]}', responsetext, flags=re.M)
r"Group=(.+):(.+)",
rf"Group=\1:{baseperm[0]}",
responsetext,
flags=re.M,
)
for congrp in confgrps: for congrp in confgrps:
responsetext = re.sub( responsetext = re.sub(rf"^Group=({congrp[0]}):(.+)", rf"Group=\1:{congrp[1]}", responsetext, flags=re.M)
rf"^Group=({congrp[0]}):(.+)", self.wfile.write(responsetext.encode('utf-8'))
rf"Group=\1:{congrp[1]}", with open(f"./wlgrps/backup-{grpName}.cfg", 'wb') as backupfile:
responsetext, backupfile.write(responsetext.encode('utf-8'))
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( self.send_error(400, 'please specify the group to pull from', 'no grpName specified!')
400, "please specify the group to pull from", "no grpName specified!"
)
return return
@ -87,7 +71,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!")