2021-01-15 19:59:58 +00:00
|
|
|
import os
|
2021-06-02 18:47:08 +00:00
|
|
|
import html
|
2022-06-15 23:10:26 +00:00
|
|
|
import pathlib
|
2021-08-11 20:29:31 +00:00
|
|
|
import re
|
2022-01-26 01:45:30 +00:00
|
|
|
import logging
|
2022-03-01 22:10:04 +00:00
|
|
|
import time
|
2022-12-01 01:28:24 +00:00
|
|
|
import urllib.parse
|
2022-04-11 05:23:55 +00:00
|
|
|
import bleach
|
|
|
|
import tornado.web
|
|
|
|
import tornado.escape
|
2020-09-02 01:30:39 +00:00
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
from app.classes.models.server_permissions import EnumPermissionsServer
|
2022-04-12 01:34:46 +00:00
|
|
|
from app.classes.shared.console import Console
|
2022-04-11 05:23:55 +00:00
|
|
|
from app.classes.shared.helpers import Helpers
|
2021-08-10 20:17:56 +00:00
|
|
|
from app.classes.shared.server import ServerOutBuf
|
2022-01-26 01:45:30 +00:00
|
|
|
from app.classes.web.base_handler import BaseHandler
|
2020-09-02 01:30:39 +00:00
|
|
|
|
2022-03-08 04:40:44 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
2020-09-02 01:30:39 +00:00
|
|
|
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
class AjaxHandler(BaseHandler):
|
2020-09-02 01:30:39 +00:00
|
|
|
def render_page(self, template, page_data):
|
|
|
|
self.render(
|
|
|
|
template,
|
2021-03-26 13:57:50 +00:00
|
|
|
data=page_data,
|
|
|
|
translate=self.translator.translate,
|
2020-09-02 01:30:39 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
@tornado.web.authenticated
|
|
|
|
def get(self, page):
|
2022-01-15 00:23:50 +00:00
|
|
|
_, _, exec_user = self.current_user
|
2022-03-23 02:50:12 +00:00
|
|
|
error = bleach.clean(self.get_argument("error", "WTF Error!"))
|
2020-09-02 01:30:39 +00:00
|
|
|
|
|
|
|
template = "panel/denied.html"
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
page_data = {"user_data": exec_user, "error": error}
|
2020-09-02 01:30:39 +00:00
|
|
|
|
|
|
|
if page == "error":
|
|
|
|
template = "public/error.html"
|
|
|
|
self.render_page(template, page_data)
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
elif page == "server_log":
|
|
|
|
server_id = self.get_argument("id", None)
|
|
|
|
full_log = self.get_argument("full", False)
|
2020-09-02 01:30:39 +00:00
|
|
|
|
|
|
|
if server_id is None:
|
|
|
|
logger.warning("Server ID not found in server_log ajax call")
|
|
|
|
self.redirect("/panel/error?error=Server ID Not Found")
|
2021-07-30 16:20:01 +00:00
|
|
|
return
|
2020-09-02 01:30:39 +00:00
|
|
|
|
|
|
|
server_id = bleach.clean(server_id)
|
|
|
|
|
2021-09-25 21:05:49 +00:00
|
|
|
server_data = self.controller.servers.get_server_data_by_id(server_id)
|
2020-09-02 01:30:39 +00:00
|
|
|
if not server_data:
|
|
|
|
logger.warning("Server Data not found in server_log ajax call")
|
|
|
|
self.redirect("/panel/error?error=Server ID Not Found")
|
2021-08-10 20:17:56 +00:00
|
|
|
return
|
2020-09-02 01:30:39 +00:00
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
if not server_data["log_path"]:
|
|
|
|
logger.warning(
|
|
|
|
f"Log path not found in server_log ajax call ({server_id})"
|
|
|
|
)
|
2020-09-02 01:30:39 +00:00
|
|
|
|
2020-09-04 02:49:20 +00:00
|
|
|
if full_log:
|
2022-04-11 05:23:55 +00:00
|
|
|
log_lines = self.helper.get_setting("max_log_lines")
|
|
|
|
data = Helpers.tail_file(
|
2022-06-15 23:10:26 +00:00
|
|
|
# If the log path is absolute it returns it as is
|
|
|
|
# If it is relative it joins the paths below like normal
|
|
|
|
pathlib.Path(server_data["path"], server_data["log_path"]),
|
2022-03-23 02:50:12 +00:00
|
|
|
log_lines,
|
|
|
|
)
|
2020-09-04 02:49:20 +00:00
|
|
|
else:
|
2021-08-10 20:17:56 +00:00
|
|
|
data = ServerOutBuf.lines.get(server_id, [])
|
2020-09-04 02:49:20 +00:00
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
for line in data:
|
2020-09-02 01:30:39 +00:00
|
|
|
try:
|
2022-05-15 01:53:18 +00:00
|
|
|
line = re.sub("(\033\\[(0;)?[0-9]*[A-z]?(;[0-9])?m?)", "", line)
|
2022-04-14 02:10:25 +00:00
|
|
|
line = re.sub("[A-z]{2}\b\b", "", line)
|
|
|
|
line = self.helper.log_colors(html.escape(line))
|
2022-10-13 03:29:20 +00:00
|
|
|
self.write(f"<span class='box'>{line}<br /></span>")
|
2020-09-02 01:30:39 +00:00
|
|
|
# self.write(d.encode("utf-8"))
|
|
|
|
|
|
|
|
except Exception as e:
|
2022-01-26 01:45:30 +00:00
|
|
|
logger.warning(f"Skipping Log Line due to error: {e}")
|
2020-09-02 01:30:39 +00:00
|
|
|
|
2020-09-23 01:42:41 +00:00
|
|
|
elif page == "announcements":
|
2022-04-11 05:23:55 +00:00
|
|
|
data = Helpers.get_announcements()
|
2022-03-23 02:50:12 +00:00
|
|
|
page_data["notify_data"] = data
|
|
|
|
self.render_page("ajax/notify.html", page_data)
|
2022-01-26 01:45:30 +00:00
|
|
|
|
2022-01-10 03:21:28 +00:00
|
|
|
elif page == "get_zip_tree":
|
2022-03-23 02:50:12 +00:00
|
|
|
path = self.get_argument("path", None)
|
2022-01-10 03:21:28 +00:00
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
self.write(
|
2022-04-11 05:23:55 +00:00
|
|
|
Helpers.get_os_understandable_path(path)
|
2022-03-23 02:50:12 +00:00
|
|
|
+ "\n"
|
2022-04-11 05:23:55 +00:00
|
|
|
+ Helpers.generate_zip_tree(path)
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2022-01-10 03:21:28 +00:00
|
|
|
self.finish()
|
|
|
|
|
|
|
|
elif page == "get_zip_dir":
|
2022-03-23 02:50:12 +00:00
|
|
|
path = self.get_argument("path", None)
|
2022-01-10 03:21:28 +00:00
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
self.write(
|
2022-04-11 05:23:55 +00:00
|
|
|
Helpers.get_os_understandable_path(path)
|
2022-03-23 02:50:12 +00:00
|
|
|
+ "\n"
|
2022-04-11 05:23:55 +00:00
|
|
|
+ Helpers.generate_zip_dir(path)
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2022-01-10 03:21:28 +00:00
|
|
|
self.finish()
|
2022-01-26 01:45:30 +00:00
|
|
|
|
2022-03-01 01:02:30 +00:00
|
|
|
elif page == "get_dir":
|
2022-03-23 02:50:12 +00:00
|
|
|
server_id = self.get_argument("id", None)
|
|
|
|
path = self.get_argument("path", None)
|
2022-03-01 01:02:30 +00:00
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
if not self.check_server_id(server_id, "get_tree"):
|
2022-03-01 01:02:30 +00:00
|
|
|
return
|
2022-06-14 12:40:57 +00:00
|
|
|
server_id = bleach.clean(server_id)
|
2022-03-01 01:02:30 +00:00
|
|
|
|
2022-04-11 05:23:55 +00:00
|
|
|
if Helpers.validate_traversal(
|
2022-03-23 02:50:12 +00:00
|
|
|
self.controller.servers.get_server_data_by_id(server_id)["path"], path
|
|
|
|
):
|
|
|
|
self.write(
|
2022-04-11 05:23:55 +00:00
|
|
|
Helpers.get_os_understandable_path(path)
|
2022-03-23 02:50:12 +00:00
|
|
|
+ "\n"
|
2022-04-11 05:23:55 +00:00
|
|
|
+ Helpers.generate_dir(path)
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2022-03-01 01:02:30 +00:00
|
|
|
self.finish()
|
2021-01-17 17:20:28 +00:00
|
|
|
|
2021-01-18 15:02:38 +00:00
|
|
|
@tornado.web.authenticated
|
2020-09-22 02:01:16 +00:00
|
|
|
def post(self, page):
|
2022-01-15 00:23:50 +00:00
|
|
|
api_key, _, exec_user = self.current_user
|
2022-03-23 02:50:12 +00:00
|
|
|
superuser = exec_user["superuser"]
|
2022-01-15 00:23:50 +00:00
|
|
|
if api_key is not None:
|
|
|
|
superuser = superuser and api_key.superuser
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
server_id = self.get_argument("id", None)
|
2022-01-15 00:23:50 +00:00
|
|
|
|
2023-06-04 15:48:39 +00:00
|
|
|
if page == "send_order":
|
2022-03-23 02:50:12 +00:00
|
|
|
self.controller.users.update_server_order(
|
|
|
|
exec_user["user_id"], bleach.clean(self.get_argument("order"))
|
|
|
|
)
|
2022-02-26 23:00:54 +00:00
|
|
|
return
|
2022-03-13 13:26:38 +00:00
|
|
|
|
2022-11-09 19:13:35 +00:00
|
|
|
elif page == "select_photo":
|
|
|
|
if exec_user["superuser"]:
|
2023-01-18 19:35:35 +00:00
|
|
|
photo = urllib.parse.unquote(self.get_argument("photo", ""))
|
2023-01-17 19:40:16 +00:00
|
|
|
opacity = self.get_argument("opacity", 100)
|
|
|
|
self.controller.management.set_login_opacity(int(opacity))
|
2022-11-09 19:13:35 +00:00
|
|
|
if photo == "login_1.jpg":
|
|
|
|
self.controller.management.set_login_image("login_1.jpg")
|
|
|
|
self.controller.cached_login = f"{photo}"
|
|
|
|
else:
|
|
|
|
self.controller.management.set_login_image(f"custom/{photo}")
|
|
|
|
self.controller.cached_login = f"custom/{photo}"
|
|
|
|
return
|
|
|
|
|
|
|
|
elif page == "delete_photo":
|
|
|
|
if exec_user["superuser"]:
|
2023-01-18 19:40:01 +00:00
|
|
|
photo = urllib.parse.unquote(self.get_argument("photo", None))
|
2022-11-09 19:13:35 +00:00
|
|
|
if photo and photo != "login_1.jpg":
|
|
|
|
os.remove(
|
|
|
|
os.path.join(
|
|
|
|
self.controller.project_root,
|
|
|
|
f"app/frontend/static/assets/images/auth/custom/{photo}",
|
|
|
|
)
|
|
|
|
)
|
|
|
|
current = self.controller.cached_login
|
|
|
|
split = current.split("/")
|
2022-11-09 19:20:37 +00:00
|
|
|
if len(split) == 1:
|
2022-11-09 19:13:35 +00:00
|
|
|
current_photo = current
|
|
|
|
else:
|
|
|
|
current_photo = split[1]
|
|
|
|
if current_photo == photo:
|
|
|
|
self.controller.management.set_login_image("login_1.jpg")
|
|
|
|
self.controller.cached_login = "login_1.jpg"
|
|
|
|
return
|
|
|
|
|
2021-11-23 21:11:23 +00:00
|
|
|
elif page == "eula":
|
2022-03-23 02:50:12 +00:00
|
|
|
server_id = self.get_argument("id", None)
|
2022-05-30 17:28:39 +00:00
|
|
|
svr = self.controller.servers.get_server_instance_by_id(server_id)
|
2022-03-23 02:50:12 +00:00
|
|
|
svr.agree_eula(exec_user["user_id"])
|
2021-09-13 19:03:47 +00:00
|
|
|
|
2022-01-09 23:04:54 +00:00
|
|
|
elif page == "unzip_server":
|
2022-12-15 23:58:10 +00:00
|
|
|
path = urllib.parse.unquote(self.get_argument("path", ""))
|
2022-09-28 02:06:22 +00:00
|
|
|
if not path:
|
|
|
|
path = os.path.join(
|
|
|
|
self.controller.project_root,
|
|
|
|
"imports",
|
2022-12-15 23:58:10 +00:00
|
|
|
urllib.parse.unquote(self.get_argument("file", "")),
|
2022-09-28 02:06:22 +00:00
|
|
|
)
|
2022-04-11 05:23:55 +00:00
|
|
|
if Helpers.check_file_exists(path):
|
2022-04-14 23:45:13 +00:00
|
|
|
self.helper.unzip_server(path, exec_user["user_id"])
|
2022-03-01 18:27:41 +00:00
|
|
|
else:
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id = exec_user["user_id"]
|
2022-03-01 18:27:41 +00:00
|
|
|
if user_id:
|
|
|
|
time.sleep(5)
|
|
|
|
user_lang = self.controller.users.get_user_lang_by_id(user_id)
|
2022-04-11 05:23:55 +00:00
|
|
|
self.helper.websocket_helper.broadcast_user(
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id,
|
|
|
|
"send_start_error",
|
2022-04-11 10:08:36 +00:00
|
|
|
{
|
|
|
|
"error": self.helper.translation.translate(
|
|
|
|
"error", "no-file", user_lang
|
|
|
|
)
|
|
|
|
},
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2022-01-10 03:21:28 +00:00
|
|
|
return
|
2022-01-26 01:45:30 +00:00
|
|
|
|
2022-03-01 01:02:30 +00:00
|
|
|
elif page == "backup_select":
|
2022-03-23 02:50:12 +00:00
|
|
|
path = self.get_argument("path", None)
|
2022-04-11 05:23:55 +00:00
|
|
|
self.helper.backup_select(path, exec_user["user_id"])
|
2022-03-01 01:02:30 +00:00
|
|
|
return
|
|
|
|
|
2022-08-03 19:38:44 +00:00
|
|
|
elif page == "jar_cache":
|
|
|
|
if not superuser:
|
|
|
|
self.redirect("/panel/error?error=Not a super user")
|
|
|
|
return
|
|
|
|
|
|
|
|
self.controller.server_jars.manual_refresh_cache()
|
|
|
|
return
|
|
|
|
|
2023-01-30 20:23:10 +00:00
|
|
|
elif page == "update_server_dir":
|
2023-02-20 20:36:05 +00:00
|
|
|
if self.helper.dir_migration:
|
|
|
|
return
|
2023-01-30 20:23:10 +00:00
|
|
|
for server in self.controller.servers.get_all_servers_stats():
|
|
|
|
if server["stats"]["running"]:
|
|
|
|
self.helper.websocket_helper.broadcast_user(
|
|
|
|
exec_user["user_id"],
|
|
|
|
"send_start_error",
|
|
|
|
{
|
|
|
|
"error": "You must stop all servers before "
|
|
|
|
"starting a storage migration."
|
|
|
|
},
|
|
|
|
)
|
|
|
|
return
|
|
|
|
if not superuser:
|
|
|
|
self.redirect("/panel/error?error=Not a super user")
|
|
|
|
return
|
2023-02-12 17:29:05 +00:00
|
|
|
if self.helper.is_env_docker():
|
|
|
|
self.redirect(
|
|
|
|
"/panel/error?error=This feature is not"
|
|
|
|
" supported on docker environments"
|
|
|
|
)
|
|
|
|
return
|
2023-01-30 20:23:10 +00:00
|
|
|
new_dir = urllib.parse.unquote(self.get_argument("server_dir"))
|
|
|
|
self.controller.update_master_server_dir(new_dir, exec_user["user_id"])
|
|
|
|
return
|
|
|
|
|
2021-03-26 13:57:50 +00:00
|
|
|
def check_server_id(self, server_id, page_name):
|
|
|
|
if server_id is None:
|
2022-03-23 02:50:12 +00:00
|
|
|
logger.warning(
|
|
|
|
f"Server ID not defined in {page_name} ajax call ({server_id})"
|
|
|
|
)
|
2022-04-12 01:34:46 +00:00
|
|
|
Console.warning(
|
2022-03-23 02:50:12 +00:00
|
|
|
f"Server ID not defined in {page_name} ajax call ({server_id})"
|
|
|
|
)
|
2021-07-30 16:20:01 +00:00
|
|
|
return
|
2022-06-14 12:40:57 +00:00
|
|
|
server_id = bleach.clean(server_id)
|
2021-03-26 13:57:50 +00:00
|
|
|
|
2022-06-14 12:40:57 +00:00
|
|
|
# does this server id exist?
|
|
|
|
if not self.controller.servers.server_id_exists(server_id):
|
|
|
|
logger.warning(
|
|
|
|
f"Server ID not found in {page_name} ajax call ({server_id})"
|
|
|
|
)
|
|
|
|
Console.warning(
|
|
|
|
f"Server ID not found in {page_name} ajax call ({server_id})"
|
|
|
|
)
|
|
|
|
return
|
2021-03-26 13:57:50 +00:00
|
|
|
return True
|