crafty-4/app/classes/web/panel_handler.py

147 lines
5.3 KiB
Python
Raw Normal View History

2020-08-13 14:38:36 +00:00
import json
import logging
import tornado.web
import tornado.escape
import bleach
from app.classes.shared.console import console
from app.classes.shared.models import Users, installer
2020-08-13 14:38:36 +00:00
from app.classes.web.base_handler import BaseHandler
from app.classes.shared.controller import controller
from app.classes.shared.models import db_helper, Servers
from app.classes.shared.helpers import helper
2020-08-13 14:38:36 +00:00
logger = logging.getLogger(__name__)
2020-08-13 14:38:36 +00:00
class PanelHandler(BaseHandler):
@tornado.web.authenticated
def get(self, page):
user_data = json.loads(self.get_secure_cookie("user_data"))
error = bleach.clean(self.get_argument('error', "WTF Error!"))
2020-08-13 14:38:36 +00:00
template = "panel/denied.html"
2020-08-24 17:08:17 +00:00
defined_servers = controller.list_defined_servers()
2020-08-13 14:38:36 +00:00
page_data = {
'version_data': helper.get_version_string(),
'user_data': user_data,
'server_stats': {
2020-08-24 17:08:17 +00:00
'total': len(defined_servers),
'running': len(controller.list_running_servers()),
'stopped': (len(controller.list_defined_servers()) - len(controller.list_running_servers()))
},
2020-08-24 17:08:17 +00:00
'menu_servers': defined_servers,
'hosts_data': db_helper.get_latest_hosts_stats(),
'show_contribute': helper.get_setting("show_contribute_link", True),
'error': error
2020-08-13 14:38:36 +00:00
}
# if no servers defined, let's go to the build server area
if page_data['server_stats']['total'] == 0:
self.set_status(301)
self.redirect("/server/step1")
return False
2020-08-13 14:38:36 +00:00
if page == 'unauthorized':
template = "panel/denied.html"
elif page == "error":
template = "public/error.html"
elif page == 'credits':
template = "panel/credits.html"
elif page == 'contribute':
template = "panel/contribute.html"
2020-08-13 14:38:36 +00:00
elif page == 'dashboard':
2020-08-24 17:08:17 +00:00
page_data['servers'] = db_helper.get_all_servers_stats()
for s in page_data['servers']:
try:
data = json.loads(s['int_ping_results'])
s['int_ping_results'] = data
except:
pass
2020-08-13 14:38:36 +00:00
template = "panel/dashboard.html"
elif page == 'server_detail':
server_id = self.get_argument('id', None)
subpage = bleach.clean(self.get_argument('subpage', ""))
if server_id is None:
self.redirect("/panel/error?error=Invalid Server ID")
return False
else:
server_id = bleach.clean(server_id)
# does this server id exist?
if not db_helper.server_id_exists(server_id):
self.redirect("/panel/error?error=Invalid Server ID")
return False
2020-09-04 04:02:03 +00:00
valid_subpages = ['term', 'logs', 'config']
if subpage not in valid_subpages:
subpage = 'term'
# server_data isn't needed since the server_stats also pulls server data
# page_data['server_data'] = db_helper.get_server_data_by_id(server_id)
page_data['server_stats'] = db_helper.get_server_stats_by_id(server_id)
# template = "panel/server_details.html"
template = "panel/server_{subpage}.html".format(subpage=subpage)
2020-08-13 14:38:36 +00:00
self.render(
template,
data=page_data
2020-08-24 17:08:17 +00:00
)
@tornado.web.authenticated
def post(self, page):
if page == 'server_detail':
server_id = self.get_argument('id', None)
server_name = self.get_argument('server_name', None)
server_path = self.get_argument('server_path', None)
log_path = self.get_argument('log_path', None)
executable = self.get_argument('executable', None)
execution_command = self.get_argument('execution_command', None)
stop_command = self.get_argument('stop_command', None)
auto_start_delay = self.get_argument('auto_start_delay', None)
server_port = self.get_argument('server_port', None)
auto_start = self.get_argument('auto_start', '0')
crash_detection = self.get_argument('crash_detection', '0')
subpage = self.get_argument('subpage', None)
if server_id is None:
self.redirect("/panel/error?error=Invalid Server ID")
return False
else:
server_id = bleach.clean(server_id)
# does this server id exist?
if not db_helper.server_id_exists(server_id):
self.redirect("/panel/error?error=Invalid Server ID")
return False
Servers.update({
Servers.server_name: server_name,
Servers.path: server_path,
Servers.log_path: log_path,
Servers.executable: executable,
Servers.execution_command: execution_command,
Servers.stop_command: stop_command,
Servers.auto_start_delay: auto_start_delay,
Servers.server_port: server_port,
Servers.auto_start: auto_start,
Servers.crash_detection: crash_detection,
}).where(Servers.server_id == server_id).execute()
self.redirect("/panel/server_detail?id={}&subpage=config".format(server_id))