Merge branch 'dev' into sec/bump-crypto

This commit is contained in:
Zedifus 2024-02-19 20:34:49 +00:00
commit 07c9620875
7 changed files with 173 additions and 151 deletions

View File

@ -172,9 +172,9 @@ class PermissionsServers:
RoleServers.server_id, RoleServers.permissions
).where(RoleServers.role_id == role_id)
for role_server in role_servers:
permissions_dict[
role_server.server_id_id
] = PermissionsServers.get_permissions(role_server.permissions)
permissions_dict[role_server.server_id_id] = (
PermissionsServers.get_permissions(role_server.permissions)
)
return permissions_dict
@staticmethod

View File

@ -345,7 +345,8 @@ class PanelHandler(BaseHandler):
self.controller.users.get_user_lang_by_id(exec_user["user_id"])
),
"super_user": superuser,
"api_key": {
"api_key": (
{
"name": api_key.name,
"created": api_key.created,
"server_permissions": api_key.server_permissions,
@ -353,7 +354,8 @@ class PanelHandler(BaseHandler):
"superuser": api_key.superuser,
}
if api_key is not None
else None,
else None
),
"superuser": superuser,
}
try:
@ -417,14 +419,14 @@ class PanelHandler(BaseHandler):
self.controller.first_login = False
if superuser: # TODO: Figure out a better solution
try:
page_data[
"servers"
] = self.controller.servers.get_all_servers_stats()
page_data["servers"] = (
self.controller.servers.get_all_servers_stats()
)
except IndexError:
self.controller.servers.stats.record_stats()
page_data[
"servers"
] = self.controller.servers.get_all_servers_stats()
page_data["servers"] = (
self.controller.servers.get_all_servers_stats()
)
else:
try:
user_auth = self.controller.servers.get_authorized_servers_stats(
@ -454,20 +456,20 @@ class PanelHandler(BaseHandler):
for server_id in user_order[:]:
for server in un_used_servers[:]:
if flag == 0:
server["stats"][
"importing"
] = self.controller.servers.get_import_status(
server["stats"]["importing"] = (
self.controller.servers.get_import_status(
str(server["stats"]["server_id"]["server_id"])
)
)
server["stats"]["crashed"] = self.controller.servers.is_crashed(
str(server["stats"]["server_id"]["server_id"])
)
try:
server["stats"][
"waiting_start"
] = self.controller.servers.get_waiting_start(
server["stats"]["waiting_start"] = (
self.controller.servers.get_waiting_start(
str(server["stats"]["server_id"]["server_id"])
)
)
except Exception as e:
logger.error(f"Failed to get server waiting to start: {e}")
server["stats"]["waiting_start"] = False
@ -543,9 +545,9 @@ class PanelHandler(BaseHandler):
server_id
)
if not self.failed_server:
page_data[
"server_stats"
] = self.controller.servers.get_server_stats_by_id(server_id)
page_data["server_stats"] = (
self.controller.servers.get_server_stats_by_id(server_id)
)
else:
server_temp_obj = self.controller.servers.get_server_data_by_id(
server_id
@ -611,19 +613,19 @@ class PanelHandler(BaseHandler):
"Config": EnumPermissionsServer.CONFIG,
"Players": EnumPermissionsServer.PLAYERS,
}
page_data[
"user_permissions"
] = self.controller.server_perms.get_user_id_permissions_list(
page_data["user_permissions"] = (
self.controller.server_perms.get_user_id_permissions_list(
exec_user["user_id"], server_id
)
)
if not self.failed_server:
page_data["server_stats"][
"crashed"
] = self.controller.servers.is_crashed(server_id)
page_data["server_stats"]["crashed"] = (
self.controller.servers.is_crashed(server_id)
)
if not self.failed_server:
page_data["server_stats"][
"server_type"
] = self.controller.servers.get_server_type_by_id(server_id)
page_data["server_stats"]["server_type"] = (
self.controller.servers.get_server_type_by_id(server_id)
)
if not subpage:
for spage, perm in SUBPAGE_PERMS.items():
@ -674,23 +676,23 @@ class PanelHandler(BaseHandler):
page_data["java_versions"] = page_java
if subpage == "backup":
server_info = self.controller.servers.get_server_data_by_id(server_id)
page_data[
"backup_config"
] = self.controller.management.get_backup_config(server_id)
page_data["backup_config"] = (
self.controller.management.get_backup_config(server_id)
)
exclusions = []
page_data[
"exclusions"
] = self.controller.management.get_excluded_backup_dirs(server_id)
page_data[
"backing_up"
] = self.controller.servers.get_server_instance_by_id(
page_data["exclusions"] = (
self.controller.management.get_excluded_backup_dirs(server_id)
)
page_data["backing_up"] = (
self.controller.servers.get_server_instance_by_id(
server_id
).is_backingup
page_data[
"backup_stats"
] = self.controller.servers.get_server_instance_by_id(
)
page_data["backup_stats"] = (
self.controller.servers.get_server_instance_by_id(
server_id
).send_backup_status()
)
# makes it so relative path is the only thing shown
for file in page_data["exclusions"]:
if Helpers.is_os_windows():
@ -723,11 +725,11 @@ class PanelHandler(BaseHandler):
server_id, hours=(days * 24)
)
if subpage == "webhooks":
page_data[
"webhooks"
] = self.controller.management.get_webhooks_by_server(
page_data["webhooks"] = (
self.controller.management.get_webhooks_by_server(
server_id, model=True
)
)
page_data["triggers"] = WebhookFactory.get_monitored_events()
def get_banned_players_html():
@ -758,9 +760,9 @@ class PanelHandler(BaseHandler):
if not superuser:
self.redirect("/panel/error?error=Unauthorized access")
page_data["banned_players_html"] = get_banned_players_html()
page_data[
"banned_players"
] = self.controller.servers.get_banned_players(server_id)
page_data["banned_players"] = (
self.controller.servers.get_banned_players(server_id)
)
server_instance = self.controller.servers.get_server_instance_by_id(
server_id
)
@ -925,9 +927,9 @@ class PanelHandler(BaseHandler):
if item not in page_data["backgrounds"]:
page_data["backgrounds"].append(item)
page_data["background"] = self.controller.cached_login
page_data[
"login_opacity"
] = self.controller.management.get_login_opacity()
page_data["login_opacity"] = (
self.controller.management.get_login_opacity()
)
page_data["active_link"] = "custom_login"
template = "panel/custom_login.html"
@ -959,13 +961,11 @@ class PanelHandler(BaseHandler):
page_data["servers"] = []
page_data["servers_all"] = self.controller.servers.get_all_defined_servers()
page_data["role-servers"] = []
page_data[
"permissions_all"
] = self.controller.crafty_perms.list_defined_crafty_permissions()
page_data["permissions_all"] = (
self.controller.crafty_perms.list_defined_crafty_permissions()
)
page_data["permissions_list"] = set()
page_data[
"quantity_server"
] = (
page_data["quantity_server"] = (
self.controller.crafty_perms.list_all_crafty_permissions_quantity_limits() # pylint: disable=line-too-long
)
page_data["languages"] = []
@ -1007,11 +1007,11 @@ class PanelHandler(BaseHandler):
page_data["server_data"] = self.controller.servers.get_server_data_by_id(
server_id
)
page_data[
"user_permissions"
] = self.controller.server_perms.get_user_id_permissions_list(
page_data["user_permissions"] = (
self.controller.server_perms.get_user_id_permissions_list(
exec_user["user_id"], server_id
)
)
page_data["permissions"] = {
"Commands": EnumPermissionsServer.COMMANDS,
"Terminal": EnumPermissionsServer.TERMINAL,
@ -1025,9 +1025,9 @@ class PanelHandler(BaseHandler):
page_data["server_stats"] = self.controller.servers.get_server_stats_by_id(
server_id
)
page_data["server_stats"][
"server_type"
] = self.controller.servers.get_server_type_by_id(server_id)
page_data["server_stats"]["server_type"] = (
self.controller.servers.get_server_type_by_id(server_id)
)
page_data["new_webhook"] = True
page_data["webhook"] = {}
page_data["webhook"]["webhook_type"] = "Custom"
@ -1061,11 +1061,11 @@ class PanelHandler(BaseHandler):
page_data["server_data"] = self.controller.servers.get_server_data_by_id(
server_id
)
page_data[
"user_permissions"
] = self.controller.server_perms.get_user_id_permissions_list(
page_data["user_permissions"] = (
self.controller.server_perms.get_user_id_permissions_list(
exec_user["user_id"], server_id
)
)
page_data["permissions"] = {
"Commands": EnumPermissionsServer.COMMANDS,
"Terminal": EnumPermissionsServer.TERMINAL,
@ -1079,9 +1079,9 @@ class PanelHandler(BaseHandler):
page_data["server_stats"] = self.controller.servers.get_server_stats_by_id(
server_id
)
page_data["server_stats"][
"server_type"
] = self.controller.servers.get_server_type_by_id(server_id)
page_data["server_stats"]["server_type"] = (
self.controller.servers.get_server_type_by_id(server_id)
)
page_data["new_webhook"] = False
page_data["webhook"] = self.controller.management.get_webhook_by_id(
webhook_id
@ -1121,20 +1121,20 @@ class PanelHandler(BaseHandler):
"Config": EnumPermissionsServer.CONFIG,
"Players": EnumPermissionsServer.PLAYERS,
}
page_data[
"user_permissions"
] = self.controller.server_perms.get_user_id_permissions_list(
page_data["user_permissions"] = (
self.controller.server_perms.get_user_id_permissions_list(
exec_user["user_id"], server_id
)
)
page_data["server_data"] = self.controller.servers.get_server_data_by_id(
server_id
)
page_data["server_stats"] = self.controller.servers.get_server_stats_by_id(
server_id
)
page_data["server_stats"][
"server_type"
] = self.controller.servers.get_server_type_by_id(server_id)
page_data["server_stats"]["server_type"] = (
self.controller.servers.get_server_type_by_id(server_id)
)
page_data["new_schedule"] = True
page_data["schedule"] = {}
page_data["schedule"]["children"] = []
@ -1189,20 +1189,20 @@ class PanelHandler(BaseHandler):
"Config": EnumPermissionsServer.CONFIG,
"Players": EnumPermissionsServer.PLAYERS,
}
page_data[
"user_permissions"
] = self.controller.server_perms.get_user_id_permissions_list(
page_data["user_permissions"] = (
self.controller.server_perms.get_user_id_permissions_list(
exec_user["user_id"], server_id
)
)
page_data["server_data"] = self.controller.servers.get_server_data_by_id(
server_id
)
page_data["server_stats"] = self.controller.servers.get_server_stats_by_id(
server_id
)
page_data["server_stats"][
"server_type"
] = self.controller.servers.get_server_type_by_id(server_id)
page_data["server_stats"]["server_type"] = (
self.controller.servers.get_server_type_by_id(server_id)
)
page_data["new_schedule"] = False
page_data["schedule"] = {}
page_data["schedule"]["server_id"] = server_id
@ -1212,9 +1212,9 @@ class PanelHandler(BaseHandler):
page_data["schedule"]["name"] = schedule.name
else:
page_data["schedule"]["name"] = ""
page_data["schedule"][
"children"
] = self.controller.management.get_child_schedules(sch_id)
page_data["schedule"]["children"] = (
self.controller.management.get_child_schedules(sch_id)
)
# We check here to see if the command is any of the default ones.
# We do not want a user changing to a custom command
# and seeing our command there.
@ -1280,17 +1280,17 @@ class PanelHandler(BaseHandler):
}
if exec_user["superuser"]:
page_data["users"] = self.controller.users.get_all_users()
page_data[
"permissions_all"
] = self.controller.crafty_perms.list_defined_crafty_permissions()
page_data[
"permissions_list"
] = self.controller.crafty_perms.get_crafty_permissions_list(user_id)
page_data[
"quantity_server"
] = self.controller.crafty_perms.list_crafty_permissions_quantity_limits(
page_data["permissions_all"] = (
self.controller.crafty_perms.list_defined_crafty_permissions()
)
page_data["permissions_list"] = (
self.controller.crafty_perms.get_crafty_permissions_list(user_id)
)
page_data["quantity_server"] = (
self.controller.crafty_perms.list_crafty_permissions_quantity_limits(
user_id
)
)
page_data["languages"] = []
page_data["languages"].append(
self.controller.users.get_user_lang_by_id(user_id)
@ -1349,12 +1349,12 @@ class PanelHandler(BaseHandler):
page_data["user"] = self.controller.users.get_user_by_id(user_id)
page_data["api_keys"] = self.controller.users.get_user_api_keys(user_id)
# self.controller.crafty_perms.list_defined_crafty_permissions()
page_data[
"server_permissions_all"
] = self.controller.server_perms.list_defined_permissions()
page_data[
"crafty_permissions_all"
] = self.controller.crafty_perms.list_defined_crafty_permissions()
page_data["server_permissions_all"] = (
self.controller.server_perms.list_defined_permissions()
)
page_data["crafty_permissions_all"] = (
self.controller.crafty_perms.list_defined_crafty_permissions()
)
if user_id is None:
self.redirect("/panel/error?error=Invalid User ID")
@ -1442,9 +1442,9 @@ class PanelHandler(BaseHandler):
DatabaseShortcuts.get_data_obj(server.server_object)
)
page_data["servers_all"] = page_servers
page_data[
"permissions_all"
] = self.controller.server_perms.list_defined_permissions()
page_data["permissions_all"] = (
self.controller.server_perms.list_defined_permissions()
)
page_data["permissions_dict"] = {}
template = "panel/panel_edit_role.html"
@ -1467,12 +1467,12 @@ class PanelHandler(BaseHandler):
DatabaseShortcuts.get_data_obj(server.server_object)
)
page_data["servers_all"] = page_servers
page_data[
"permissions_all"
] = self.controller.server_perms.list_defined_permissions()
page_data[
"permissions_dict"
] = self.controller.server_perms.get_role_permissions_dict(role_id)
page_data["permissions_all"] = (
self.controller.server_perms.list_defined_permissions()
)
page_data["permissions_dict"] = (
self.controller.server_perms.get_role_permissions_dict(role_id)
)
page_data["user-roles"] = user_roles
page_data["users"] = self.controller.users.get_all_users()

View File

@ -80,9 +80,13 @@ class ApiCraftyConfigIndexHandler(BaseApiHandler):
200,
{
"status": "ok",
"data": self.controller.roles.get_all_role_ids()
"data": (
self.controller.roles.get_all_role_ids()
if get_only_ids
else [model_to_dict(r) for r in self.controller.roles.get_all_roles()],
else [
model_to_dict(r) for r in self.controller.roles.get_all_roles()
]
),
},
)
@ -158,9 +162,13 @@ class ApiCraftyCustomizeIndexHandler(BaseApiHandler):
200,
{
"status": "ok",
"data": self.controller.roles.get_all_role_ids()
"data": (
self.controller.roles.get_all_role_ids()
if get_only_ids
else [model_to_dict(r) for r in self.controller.roles.get_all_roles()],
else [
model_to_dict(r) for r in self.controller.roles.get_all_roles()
]
),
},
)

View File

@ -36,9 +36,13 @@ class ApiCraftyConfigServerDirHandler(BaseApiHandler):
200,
{
"status": "ok",
"data": self.controller.roles.get_all_role_ids()
"data": (
self.controller.roles.get_all_role_ids()
if get_only_ids
else [model_to_dict(r) for r in self.controller.roles.get_all_roles()],
else [
model_to_dict(r) for r in self.controller.roles.get_all_roles()
]
),
},
)

View File

@ -87,9 +87,13 @@ class ApiRolesIndexHandler(BaseApiHandler):
200,
{
"status": "ok",
"data": self.controller.roles.get_all_role_ids()
"data": (
self.controller.roles.get_all_role_ids()
if get_only_ids
else [model_to_dict(r) for r in self.controller.roles.get_all_roles()],
else [
model_to_dict(r) for r in self.controller.roles.get_all_roles()
]
),
},
)

View File

@ -25,8 +25,12 @@ class ApiRolesRoleServersHandler(BaseApiHandler):
200,
{
"status": "ok",
"data": PermissionsServers.get_server_ids_from_role(role_id)
"data": (
PermissionsServers.get_server_ids_from_role(role_id)
if get_only_ids
else self.controller.roles.get_server_ids_and_perms_from_role(role_id),
else self.controller.roles.get_server_ids_and_perms_from_role(
role_id
)
),
},
)

View File

@ -118,7 +118,8 @@ class ServerHandler(BaseHandler):
"lang_page": Helpers.get_lang_page(
self.controller.users.get_user_lang_by_id(exec_user["user_id"])
),
"api_key": {
"api_key": (
{
"name": api_key.name,
"created": api_key.created,
"server_permissions": api_key.server_permissions,
@ -126,7 +127,8 @@ class ServerHandler(BaseHandler):
"superuser": api_key.superuser,
}
if api_key is not None
else None,
else None
),
"superuser": superuser,
}