Merge branch 'dev' into refactor/remote-comms-api

This commit is contained in:
amcmanu3 2023-03-04 12:54:53 -05:00
commit 343b4c9da8
8 changed files with 74 additions and 28 deletions

View File

@ -13,12 +13,16 @@
- Bump Cryptography/pyOpenSSL for CVE-2023-23931 ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/554)) - Bump Cryptography/pyOpenSSL for CVE-2023-23931 ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/554))
- Fix debug logging to only display with the -v (verbose) flag ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/560)) - Fix debug logging to only display with the -v (verbose) flag ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/560))
- Optimize world size calculation ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/550)) - Optimize world size calculation ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/550))
- Only copy bedrock_server executable on update ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/562))
- Fix bug where unloaded servers could not be deleted ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/566))
- Fix bug where "servers" was not appended ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/567))
### Tweaks ### Tweaks
- Cleanup authentication helpers ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/545)) - Cleanup authentication helpers ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/545))
- Optimize file upload progress WS ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/546)) - Optimize file upload progress WS ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/546))
- Truncate sidebar servers to a max of 10 ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/552)) - Truncate sidebar servers to a max of 10 ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/552))
- Upgrade to FA 6. Add Translations ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/549))([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/558)) - Upgrade to FA 6. Add Translations ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/549))([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/558))
- Forge installer and Java Detection improvements ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/559)) - Forge installer and Java Detection improvements ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/559))
- Crafty log clean up -config option ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/563))
### Lang ### Lang
- Add additional translations to backups page strings ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/543)) - Add additional translations to backups page strings ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/543))
- Add additional missing translations ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/549)) - Add additional missing translations ([Merge Request](https://gitlab.com/crafty-controller/crafty-4/-/merge_requests/549))

View File

@ -18,6 +18,8 @@ Discord Server - https://discord.gg/9VJPhCE
Git Repository - https://gitlab.com/crafty-controller/crafty-4 Git Repository - https://gitlab.com/crafty-controller/crafty-4
Docker Hub - [arcadiatechnology/crafty-4](https://hub.docker.com/r/arcadiatechnology/crafty-4)
<br> <br>
## Basic Docker Usage 🐳 ## Basic Docker Usage 🐳

View File

@ -283,27 +283,31 @@ class FileHelpers:
return True return True
@staticmethod @staticmethod
def unzip_file(zip_path): def unzip_file(zip_path, server_update=False):
new_dir_list = zip_path.split("/") ignored_names = ["server.properties", "permissions.json", "allowlist.json"]
new_dir = "" # Get directory without zipfile name
for i in range(len(new_dir_list) - 1): new_dir = pathlib.Path(zip_path).parents[0]
if i == 0: # make sure we're able to access the zip file
new_dir += new_dir_list[i]
else:
new_dir += "/" + new_dir_list[i]
if Helpers.check_file_perms(zip_path) and os.path.isfile(zip_path): if Helpers.check_file_perms(zip_path) and os.path.isfile(zip_path):
# make sure the directory we're unzipping this to exists
Helpers.ensure_dir_exists(new_dir) Helpers.ensure_dir_exists(new_dir)
# we'll make a temporary directory to unzip this to.
temp_dir = tempfile.mkdtemp() temp_dir = tempfile.mkdtemp()
try: try:
with zipfile.ZipFile(zip_path, "r") as zip_ref: with zipfile.ZipFile(zip_path, "r") as zip_ref:
# we'll extract this to the temp dir using zipfile module
zip_ref.extractall(temp_dir) zip_ref.extractall(temp_dir)
full_root_path = temp_dir # we'll iterate through the top level directory moving everything
for item in os.listdir(full_root_path): # out of the temp directory and into it's final home.
if os.path.isdir(os.path.join(full_root_path, item)): for item in os.listdir(temp_dir):
# if the file is one of our ignored names we'll skip it
if item in ignored_names and server_update:
continue
# we handle files and dirs differently or we'll crash out.
if os.path.isdir(os.path.join(temp_dir, item)):
try: try:
FileHelpers.move_dir_exist( FileHelpers.move_dir_exist(
os.path.join(full_root_path, item), os.path.join(temp_dir, item),
os.path.join(new_dir, item), os.path.join(new_dir, item),
) )
except Exception as ex: except Exception as ex:
@ -311,7 +315,7 @@ class FileHelpers:
else: else:
try: try:
FileHelpers.move_file( FileHelpers.move_file(
os.path.join(full_root_path, item), os.path.join(temp_dir, item),
os.path.join(new_dir, item), os.path.join(new_dir, item),
) )
except Exception as ex: except Exception as ex:

View File

@ -465,6 +465,7 @@ class Helpers:
"reset_secrets_on_next_boot": False, "reset_secrets_on_next_boot": False,
"monitored_mounts": mounts, "monitored_mounts": mounts,
"dir_size_poll_freq_minutes": 5, "dir_size_poll_freq_minutes": 5,
"crafty_logs_delete_after_days": 0,
} }
def get_all_settings(self): def get_all_settings(self):

View File

@ -1024,6 +1024,7 @@ class Controller:
def t_update_master_server_dir(self, new_server_path, user_id): def t_update_master_server_dir(self, new_server_path, user_id):
new_server_path = self.helper.wtol_path(new_server_path) new_server_path = self.helper.wtol_path(new_server_path)
new_server_path = os.path.join(new_server_path, "servers")
self.helper.websocket_helper.broadcast_page( self.helper.websocket_helper.broadcast_page(
"/panel/panel_config", "move_status", "Checking dir" "/panel/panel_config", "move_status", "Checking dir"
) )
@ -1055,7 +1056,7 @@ class Controller:
self.helper.websocket_helper.broadcast_page( self.helper.websocket_helper.broadcast_page(
"/panel/panel_config", "move_status", "Checking permissions" "/panel/panel_config", "move_status", "Checking permissions"
) )
if not self.helper.ensure_dir_exists(os.path.join(new_server_path, "servers")): if not self.helper.ensure_dir_exists(new_server_path):
self.helper.websocket_helper.broadcast_user( self.helper.websocket_helper.broadcast_user(
user_id, user_id,
"send_start_error", "send_start_error",
@ -1074,8 +1075,8 @@ class Controller:
# move the servers # move the servers
for server in servers: for server in servers:
server_path = server.get("path") server_path = server.get("path")
new_server_path = os.path.join( new_local_server_path = os.path.join(
new_server_path, "servers", server.get("server_uuid") new_server_path, server.get("server_uuid")
) )
if os.path.isdir(server_path): if os.path.isdir(server_path):
self.helper.websocket_helper.broadcast_page( self.helper.websocket_helper.broadcast_page(
@ -1086,7 +1087,7 @@ class Controller:
try: try:
self.file_helper.move_dir( self.file_helper.move_dir(
server_path, server_path,
new_server_path, new_local_server_path,
) )
except FileExistsError as e: except FileExistsError as e:
logger.error(f"Failed to move server with error: {e}") logger.error(f"Failed to move server with error: {e}")
@ -1096,19 +1097,19 @@ class Controller:
# reset executable path # reset executable path
if current_master in server["executable"]: if current_master in server["executable"]:
server_obj.executable = str(server["executable"]).replace( server_obj.executable = str(server["executable"]).replace(
current_master, new_server_path current_master, new_local_server_path
) )
# reset run command path # reset run command path
if current_master in server["execution_command"]: if current_master in server["execution_command"]:
server_obj.execution_command = str(server["execution_command"]).replace( server_obj.execution_command = str(server["execution_command"]).replace(
current_master, new_server_path current_master, new_local_server_path
) )
# reset log path # reset log path
if current_master in server["log_path"]: if current_master in server["log_path"]:
server_obj.log_path = str(server["log_path"]).replace( server_obj.log_path = str(server["log_path"]).replace(
current_master, new_server_path current_master, new_local_server_path
) )
server_obj.path = new_server_path server_obj.path = new_local_server_path
failed = False failed = False
for s in self.servers.failed_servers: for s in self.servers.failed_servers:
if int(s["server_id"]) == int(server.get("server_id")): if int(s["server_id"]) == int(server.get("server_id")):

View File

@ -1320,7 +1320,7 @@ class ServerInstance:
unzip_path = os.path.join(self.settings["path"], "bedrock_server.zip") unzip_path = os.path.join(self.settings["path"], "bedrock_server.zip")
unzip_path = self.helper.wtol_path(unzip_path) unzip_path = self.helper.wtol_path(unzip_path)
# unzips archive that was downloaded. # unzips archive that was downloaded.
FileHelpers.unzip_file(unzip_path) FileHelpers.unzip_file(unzip_path, server_update=True)
# adjusts permissions for execution if os is not windows # adjusts permissions for execution if os is not windows
if not self.helper.is_os_windows(): if not self.helper.is_os_windows():
os.chmod( os.chmod(
@ -1334,6 +1334,7 @@ class ServerInstance:
logger.critical( logger.critical(
f"Failed to download bedrock executable for update \n{e}" f"Failed to download bedrock executable for update \n{e}"
) )
downloaded = False
if downloaded: if downloaded:
logger.info("Executable updated successfully. Starting Server") logger.info("Executable updated successfully. Starting Server")

View File

@ -752,10 +752,42 @@ class TasksManager:
logger.debug("Could not clear out file from import directory") logger.debug("Could not clear out file from import directory")
def log_watcher(self): def log_watcher(self):
self.controller.servers.check_for_old_logs() self.check_for_old_logs()
self.scheduler.add_job( self.scheduler.add_job(
self.controller.servers.check_for_old_logs, self.check_for_old_logs,
"interval", "interval",
hours=6, hours=6,
id="log-mgmt", id="log-mgmt",
) )
def check_for_old_logs(self):
# check for server logs first
self.controller.servers.check_for_old_logs()
# check for crafty logs now
logs_path = os.path.join(self.controller.project_root, "logs")
logs_delete_after = int(
self.helper.get_setting("crafty_logs_delete_after_days")
)
latest_log_files = [
"session.log",
"schedule.log",
"tornado-access.log",
"session.log",
"commander.log",
]
# we won't delete if delete logs after is set to 0
if logs_delete_after != 0:
log_files = list(
filter(
lambda val: val not in latest_log_files,
os.listdir(logs_path),
)
)
for log_file in log_files:
log_file_path = os.path.join(logs_path, log_file)
if Helpers.check_file_exists(
log_file_path
) and Helpers.is_file_older_than_x_days(
log_file_path, logs_delete_after
):
os.remove(log_file_path)

View File

@ -539,6 +539,7 @@ class PanelHandler(BaseHandler):
"auto_start": server_temp_obj["auto_start"], "auto_start": server_temp_obj["auto_start"],
"crash_detection": server_temp_obj["crash_detection"], "crash_detection": server_temp_obj["crash_detection"],
"show_status": server_temp_obj["show_status"], "show_status": server_temp_obj["show_status"],
"ignored_exits": server_temp_obj["ignored_exits"],
}, },
"running": False, "running": False,
"crashed": False, "crashed": False,
@ -848,9 +849,9 @@ class PanelHandler(BaseHandler):
page_data["auth-servers"] = auth_servers page_data["auth-servers"] = auth_servers
page_data["role-servers"] = auth_role_servers page_data["role-servers"] = auth_role_servers
page_data["user-roles"] = user_roles page_data["user-roles"] = user_roles
page_data[ page_data["servers_dir"], _tail = os.path.split(
"servers_dir" self.controller.management.get_master_server_dir()
] = self.controller.management.get_master_server_dir() )
page_data["users"] = self.controller.users.user_query(exec_user["user_id"]) page_data["users"] = self.controller.users.user_query(exec_user["user_id"])
page_data["roles"] = self.controller.users.user_role_query( page_data["roles"] = self.controller.users.user_role_query(