2020-08-19 17:54:10 +00:00
|
|
|
import json
|
|
|
|
import logging
|
2022-04-11 05:23:55 +00:00
|
|
|
import tornado.web
|
|
|
|
import tornado.escape
|
2020-08-19 17:54:10 +00:00
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
from app.classes.models.crafty_permissions import EnumPermissionsCrafty
|
2024-08-11 17:31:55 +00:00
|
|
|
from app.classes.helpers.helpers import Helpers
|
2022-05-30 20:05:36 +00:00
|
|
|
from app.classes.shared.main_models import DatabaseShortcuts
|
2020-08-19 17:54:10 +00:00
|
|
|
from app.classes.web.base_handler import BaseHandler
|
|
|
|
|
2022-03-08 04:40:44 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
2020-08-19 17:54:10 +00:00
|
|
|
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
class ServerHandler(BaseHandler):
|
2022-06-21 05:18:19 +00:00
|
|
|
def get_user_roles(self):
|
|
|
|
user_roles = {}
|
|
|
|
for user_id in self.controller.users.get_all_user_ids():
|
|
|
|
user_roles_list = self.controller.users.get_user_roles_names(user_id)
|
|
|
|
# user_servers =
|
|
|
|
# self.controller.servers.get_authorized_servers(user.user_id)
|
|
|
|
user_roles[user_id] = user_roles_list
|
|
|
|
return user_roles
|
|
|
|
|
2020-08-19 17:54:10 +00:00
|
|
|
@tornado.web.authenticated
|
|
|
|
def get(self, page):
|
2022-04-14 02:10:25 +00:00
|
|
|
(
|
|
|
|
api_key,
|
|
|
|
_token_data,
|
|
|
|
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:
|
2024-03-17 16:50:11 +00:00
|
|
|
superuser = superuser and api_key.full_access
|
2021-10-09 08:32:52 +00:00
|
|
|
|
2022-01-15 00:23:50 +00:00
|
|
|
if superuser:
|
2022-05-26 12:50:20 +00:00
|
|
|
defined_servers = self.controller.servers.list_defined_servers()
|
2022-05-15 21:55:22 +00:00
|
|
|
exec_user_role = {"Super User"}
|
2022-03-23 02:50:12 +00:00
|
|
|
exec_user_crafty_permissions = (
|
|
|
|
self.controller.crafty_perms.list_defined_crafty_permissions()
|
|
|
|
)
|
2021-11-17 18:08:41 +00:00
|
|
|
list_roles = []
|
|
|
|
for role in self.controller.roles.get_all_roles():
|
|
|
|
list_roles.append(self.controller.roles.get_role(role.role_id))
|
2021-03-13 22:12:42 +00:00
|
|
|
else:
|
2022-03-23 02:50:12 +00:00
|
|
|
exec_user_crafty_permissions = (
|
|
|
|
self.controller.crafty_perms.get_crafty_permissions_list(
|
|
|
|
exec_user["user_id"]
|
|
|
|
)
|
|
|
|
)
|
|
|
|
defined_servers = self.controller.servers.get_authorized_servers(
|
|
|
|
exec_user["user_id"]
|
|
|
|
)
|
2021-11-17 18:08:41 +00:00
|
|
|
list_roles = []
|
2022-05-15 21:55:22 +00:00
|
|
|
exec_user_role = set()
|
2022-03-23 02:50:12 +00:00
|
|
|
for r in exec_user["roles"]:
|
2021-09-08 22:01:10 +00:00
|
|
|
role = self.controller.roles.get_role(r)
|
2022-03-23 02:50:12 +00:00
|
|
|
exec_user_role.add(role["role_name"])
|
|
|
|
list_roles.append(self.controller.roles.get_role(role["role_id"]))
|
2020-08-19 17:54:10 +00:00
|
|
|
|
2022-07-18 21:12:43 +00:00
|
|
|
user_order = self.controller.users.get_user_by_id(exec_user["user_id"])
|
|
|
|
user_order = user_order["server_order"].split(",")
|
2022-05-30 20:05:36 +00:00
|
|
|
page_servers = []
|
2022-07-18 21:12:43 +00:00
|
|
|
server_ids = []
|
|
|
|
|
|
|
|
for server_id in user_order[:]:
|
|
|
|
for server in defined_servers[:]:
|
|
|
|
if str(server.server_id) == str(server_id):
|
|
|
|
page_servers.append(
|
|
|
|
DatabaseShortcuts.get_data_obj(server.server_object)
|
|
|
|
)
|
|
|
|
user_order.remove(server_id)
|
|
|
|
defined_servers.remove(server)
|
|
|
|
|
2022-05-30 20:05:36 +00:00
|
|
|
for server in defined_servers:
|
2022-07-18 21:12:43 +00:00
|
|
|
server_ids.append(str(server.server_id))
|
2022-05-30 20:05:36 +00:00
|
|
|
if server not in page_servers:
|
|
|
|
page_servers.append(
|
|
|
|
DatabaseShortcuts.get_data_obj(server.server_object)
|
|
|
|
)
|
2022-07-18 21:12:43 +00:00
|
|
|
|
|
|
|
for server_id in user_order[:]:
|
|
|
|
# remove IDs in list that user no longer has access to
|
|
|
|
if str(server_id) not in server_ids:
|
|
|
|
user_order.remove(server_id)
|
2022-05-30 20:05:36 +00:00
|
|
|
defined_servers = page_servers
|
|
|
|
|
2020-08-19 17:54:10 +00:00
|
|
|
template = "public/404.html"
|
|
|
|
|
2024-02-01 04:06:37 +00:00
|
|
|
if exec_user["username"] == "anti-lockout-user":
|
|
|
|
return self.redirect("/panel/panel_config")
|
|
|
|
|
2020-08-19 17:54:10 +00:00
|
|
|
page_data = {
|
2022-08-05 01:56:26 +00:00
|
|
|
"update_available": self.helper.update_available,
|
2022-04-11 05:23:55 +00:00
|
|
|
"version_data": self.helper.get_version_string(),
|
2022-03-23 02:50:12 +00:00
|
|
|
"user_data": exec_user,
|
|
|
|
"user_role": exec_user_role,
|
2022-08-31 23:45:19 +00:00
|
|
|
"online": Helpers.check_internet(),
|
2022-03-23 02:50:12 +00:00
|
|
|
"roles": list_roles,
|
2022-08-03 19:38:44 +00:00
|
|
|
"super_user": exec_user["superuser"],
|
2022-03-23 02:50:12 +00:00
|
|
|
"user_crafty_permissions": exec_user_crafty_permissions,
|
|
|
|
"crafty_permissions": {
|
2022-04-14 02:10:25 +00:00
|
|
|
"Server_Creation": EnumPermissionsCrafty.SERVER_CREATION,
|
|
|
|
"User_Config": EnumPermissionsCrafty.USER_CONFIG,
|
|
|
|
"Roles_Config": EnumPermissionsCrafty.ROLES_CONFIG,
|
2021-08-24 21:07:00 +00:00
|
|
|
},
|
2022-03-23 02:50:12 +00:00
|
|
|
"server_stats": {
|
2022-05-26 12:50:20 +00:00
|
|
|
"total": len(self.controller.servers.list_defined_servers()),
|
|
|
|
"running": len(self.controller.servers.list_running_servers()),
|
2022-03-23 02:50:12 +00:00
|
|
|
"stopped": (
|
2022-05-26 12:50:20 +00:00
|
|
|
len(self.controller.servers.list_defined_servers())
|
|
|
|
- len(self.controller.servers.list_running_servers())
|
2022-03-23 02:50:12 +00:00
|
|
|
),
|
2020-08-19 17:54:10 +00:00
|
|
|
},
|
2022-03-23 02:50:12 +00:00
|
|
|
"hosts_data": self.controller.management.get_latest_hosts_stats(),
|
2022-07-18 21:12:43 +00:00
|
|
|
"menu_servers": page_servers,
|
2022-04-11 05:23:55 +00:00
|
|
|
"show_contribute": self.helper.get_setting("show_contribute_link", True),
|
2022-03-23 02:50:12 +00:00
|
|
|
"lang": self.controller.users.get_user_lang_by_id(exec_user["user_id"]),
|
2022-04-14 02:10:25 +00:00
|
|
|
"lang_page": Helpers.get_lang_page(
|
2022-03-23 02:50:12 +00:00
|
|
|
self.controller.users.get_user_lang_by_id(exec_user["user_id"])
|
|
|
|
),
|
2024-02-19 20:02:09 +00:00
|
|
|
"api_key": (
|
|
|
|
{
|
|
|
|
"name": api_key.name,
|
|
|
|
"created": api_key.created,
|
|
|
|
"server_permissions": api_key.server_permissions,
|
|
|
|
"crafty_permissions": api_key.crafty_permissions,
|
2024-03-17 16:50:11 +00:00
|
|
|
"full_access": api_key.full_access,
|
2024-02-19 20:02:09 +00:00
|
|
|
}
|
|
|
|
if api_key is not None
|
|
|
|
else None
|
|
|
|
),
|
2022-03-23 02:50:12 +00:00
|
|
|
"superuser": superuser,
|
2020-08-19 17:54:10 +00:00
|
|
|
}
|
2022-03-05 11:01:36 +00:00
|
|
|
|
2022-01-15 15:38:08 +00:00
|
|
|
if superuser:
|
2022-03-23 02:50:12 +00:00
|
|
|
page_data["roles"] = list_roles
|
2020-08-23 22:43:28 +00:00
|
|
|
|
|
|
|
if page == "step1":
|
2022-03-23 02:50:12 +00:00
|
|
|
if not superuser and not self.controller.crafty_perms.can_create_server(
|
|
|
|
exec_user["user_id"]
|
|
|
|
):
|
|
|
|
self.redirect(
|
2022-03-23 06:06:13 +00:00
|
|
|
"/panel/error?error=Unauthorized access: "
|
|
|
|
"not a server creator or server limit reached"
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2021-08-24 21:07:00 +00:00
|
|
|
return
|
2023-05-14 18:23:06 +00:00
|
|
|
page_data["server_api"] = False
|
|
|
|
if page_data["online"]:
|
2024-05-05 14:12:10 +00:00
|
|
|
page_data["server_api"] = (
|
|
|
|
self.controller.big_bucket._check_bucket_alive()
|
2023-05-14 18:23:06 +00:00
|
|
|
)
|
2024-05-04 19:15:43 +00:00
|
|
|
page_data["server_types"] = self.controller.big_bucket.get_bucket_data()
|
2022-03-23 02:50:12 +00:00
|
|
|
page_data["js_server_types"] = json.dumps(
|
2024-05-04 19:15:43 +00:00
|
|
|
self.controller.big_bucket.get_bucket_data()
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2022-07-05 20:15:49 +00:00
|
|
|
if page_data["server_types"] is None:
|
|
|
|
page_data["server_types"] = []
|
|
|
|
page_data["js_server_types"] = []
|
2020-08-23 22:43:28 +00:00
|
|
|
template = "server/wizard.html"
|
|
|
|
|
2022-02-10 20:54:00 +00:00
|
|
|
if page == "bedrock_step1":
|
2022-03-23 02:50:12 +00:00
|
|
|
if not superuser and not self.controller.crafty_perms.can_create_server(
|
|
|
|
exec_user["user_id"]
|
|
|
|
):
|
|
|
|
self.redirect(
|
2022-03-23 06:06:13 +00:00
|
|
|
"/panel/error?error=Unauthorized access: "
|
|
|
|
"not a server creator or server limit reached"
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2022-02-10 20:54:00 +00:00
|
|
|
return
|
2023-05-23 01:03:29 +00:00
|
|
|
page_data["server_api"] = True
|
2022-02-10 20:54:00 +00:00
|
|
|
template = "server/bedrock_wizard.html"
|
|
|
|
|
2020-08-23 22:43:28 +00:00
|
|
|
self.render(
|
|
|
|
template,
|
2021-03-26 13:57:50 +00:00
|
|
|
data=page_data,
|
|
|
|
translate=self.translator.translate,
|
2020-08-23 22:43:28 +00:00
|
|
|
)
|