2020-08-13 10:38:36 -04:00
|
|
|
import json
|
|
|
|
import logging
|
|
|
|
import tornado.web
|
|
|
|
import tornado.escape
|
|
|
|
import bleach
|
2020-12-14 23:52:46 +02:00
|
|
|
import time
|
|
|
|
import datetime
|
2021-03-21 23:02:18 -05:00
|
|
|
import os
|
2020-08-13 10:38:36 -04:00
|
|
|
|
2021-08-08 16:43:04 -04:00
|
|
|
from tornado import iostream
|
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
from app.classes.shared.console import console
|
2020-08-16 22:47:53 -04:00
|
|
|
from app.classes.shared.models import Users, installer
|
2020-08-13 10:38:36 -04:00
|
|
|
from app.classes.web.base_handler import BaseHandler
|
2021-09-06 19:27:01 +02:00
|
|
|
from app.classes.shared.models import db_helper, server_permissions, Servers, Enum_Permissions_Server
|
|
|
|
from app.classes.shared.models_folder.crafty_permissions import crafty_permissions, Enum_Permissions_Crafty
|
2020-08-28 14:38:42 -04:00
|
|
|
from app.classes.shared.helpers import helper
|
2020-08-18 21:04:43 -04:00
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2020-08-16 22:47:53 -04:00
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
class PanelHandler(BaseHandler):
|
|
|
|
|
|
|
|
@tornado.web.authenticated
|
|
|
|
def get(self, page):
|
2020-09-01 13:29:39 -04:00
|
|
|
error = bleach.clean(self.get_argument('error', "WTF Error!"))
|
2020-08-13 10:38:36 -04:00
|
|
|
|
|
|
|
template = "panel/denied.html"
|
|
|
|
|
2020-12-14 23:52:46 +02:00
|
|
|
now = time.time()
|
|
|
|
formatted_time = str(datetime.datetime.fromtimestamp(now).strftime('%Y-%m-%d %H:%M:%S'))
|
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
exec_user_data = json.loads(self.get_secure_cookie("user_data"))
|
|
|
|
exec_user_id = exec_user_data['user_id']
|
|
|
|
exec_user = db_helper.get_user(exec_user_id)
|
2021-03-09 23:17:50 +01:00
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
exec_user_role = set()
|
|
|
|
if exec_user['superuser'] == 1:
|
2021-03-21 23:44:22 -05:00
|
|
|
defined_servers = self.controller.list_defined_servers()
|
2021-04-03 12:36:01 -05:00
|
|
|
exec_user_role.add("Super User")
|
2021-09-06 19:27:01 +02:00
|
|
|
exec_user_crafty_permissions = self.controller.crafty_perms.list_defined_crafty_permissions()
|
2021-03-09 23:17:50 +01:00
|
|
|
else:
|
2021-09-06 19:27:01 +02:00
|
|
|
exec_user_crafty_permissions = self.controller.crafty_perms.get_crafty_permissions_list(exec_user_id)
|
2021-04-03 12:36:01 -05:00
|
|
|
logger.debug(exec_user['roles'])
|
|
|
|
for r in exec_user['roles']:
|
2021-03-13 23:12:42 +01:00
|
|
|
role = db_helper.get_role(r)
|
2021-04-03 12:36:01 -05:00
|
|
|
exec_user_role.add(role['role_name'])
|
2021-08-24 23:07:00 +02:00
|
|
|
defined_servers = self.controller.list_authorized_servers(exec_user_id)
|
2020-08-18 21:04:43 -04:00
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
page_data = {
|
2020-09-22 21:43:22 -04:00
|
|
|
# todo: make this actually pull and compare version data
|
2020-09-22 21:42:41 -04:00
|
|
|
'update_available': False,
|
2020-09-01 13:29:39 -04:00
|
|
|
'version_data': helper.get_version_string(),
|
2021-04-03 12:36:01 -05:00
|
|
|
'user_data': exec_user_data,
|
|
|
|
'user_role' : exec_user_role,
|
2021-08-24 23:07:00 +02:00
|
|
|
'user_crafty_permissions' : exec_user_crafty_permissions,
|
|
|
|
'crafty_permissions': {
|
|
|
|
'Server_Creation': Enum_Permissions_Crafty.Server_Creation,
|
|
|
|
'User_Config': Enum_Permissions_Crafty.User_Config,
|
|
|
|
'Roles_Config': Enum_Permissions_Crafty.Roles_Config,
|
|
|
|
},
|
2020-08-18 21:04:43 -04:00
|
|
|
'server_stats': {
|
2020-08-24 13:08:17 -04:00
|
|
|
'total': len(defined_servers),
|
2021-03-21 23:02:18 -05:00
|
|
|
'running': len(self.controller.list_running_servers()),
|
|
|
|
'stopped': (len(self.controller.list_defined_servers()) - len(self.controller.list_running_servers()))
|
2020-08-18 21:04:43 -04:00
|
|
|
},
|
2021-08-06 13:47:06 -04:00
|
|
|
'menu_servers': defined_servers,
|
2020-08-28 14:38:42 -04:00
|
|
|
'hosts_data': db_helper.get_latest_hosts_stats(),
|
2020-09-01 13:29:39 -04:00
|
|
|
'show_contribute': helper.get_setting("show_contribute_link", True),
|
2020-12-14 23:52:46 +02:00
|
|
|
'error': error,
|
|
|
|
'time': formatted_time
|
2020-08-13 10:38:36 -04:00
|
|
|
}
|
|
|
|
|
2020-08-19 13:21:19 -04:00
|
|
|
# if no servers defined, let's go to the build server area
|
2021-05-02 18:52:10 +03:00
|
|
|
if page_data['server_stats']['total'] == 0 and page != "error" and page != "credits" and page != "contribute":
|
2021-08-24 23:07:00 +02:00
|
|
|
|
|
|
|
if Enum_Permissions_Crafty.Server_Creation not in exec_user_crafty_permissions and len(defined_servers) == 0:
|
|
|
|
logger.warning("User '" + exec_user['username'] + "#" + str(exec_user_id) + "' has access to 0 servers and is not a server creator")
|
|
|
|
else:
|
|
|
|
self.set_status(301)
|
|
|
|
self.redirect("/server/step1")
|
|
|
|
return
|
2020-08-16 22:47:53 -04:00
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
if page == 'unauthorized':
|
|
|
|
template = "panel/denied.html"
|
|
|
|
|
2020-09-01 13:29:39 -04:00
|
|
|
elif page == "error":
|
|
|
|
template = "public/error.html"
|
|
|
|
|
2020-08-27 23:21:55 -04:00
|
|
|
elif page == 'credits':
|
2021-03-13 11:07:04 -06:00
|
|
|
with open(helper.credits_cache) as republic_credits_will_do:
|
|
|
|
credits = json.load(republic_credits_will_do)
|
|
|
|
page_data["patreons"] = credits["patreons"]
|
|
|
|
page_data["staff"] = credits["staff"]
|
|
|
|
page_data["translations"] = credits["translations"]
|
2020-08-27 23:21:55 -04:00
|
|
|
template = "panel/credits.html"
|
|
|
|
|
2020-08-28 14:38:42 -04:00
|
|
|
elif page == 'contribute':
|
|
|
|
template = "panel/contribute.html"
|
|
|
|
|
2020-09-14 14:05:17 -04:00
|
|
|
elif page == "remove_server":
|
|
|
|
server_id = self.get_argument('id', None)
|
2021-04-03 12:36:01 -05:00
|
|
|
|
|
|
|
if not exec_user['superuser']:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not superuser")
|
|
|
|
return
|
|
|
|
elif server_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
|
2021-03-21 23:44:22 -05:00
|
|
|
server_data = self.controller.get_server_data(server_id)
|
2020-09-14 14:05:17 -04:00
|
|
|
server_name = server_data['server_name']
|
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
db_helper.add_to_audit_log(exec_user_data['user_id'],
|
2020-09-14 14:05:17 -04:00
|
|
|
"Deleted server {} named {}".format(server_id, server_name),
|
|
|
|
server_id,
|
|
|
|
self.get_remote_ip())
|
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
self.controller.remove_server(server_id)
|
2020-09-14 14:05:17 -04:00
|
|
|
self.redirect("/panel/dashboard")
|
|
|
|
return
|
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
elif page == 'dashboard':
|
2021-04-03 12:36:01 -05:00
|
|
|
if exec_user['superuser'] == 1:
|
2021-03-09 23:17:50 +01:00
|
|
|
page_data['servers'] = db_helper.get_all_servers_stats()
|
|
|
|
else:
|
2021-08-06 00:34:57 -04:00
|
|
|
user_auth = db_helper.get_authorized_servers_stats(exec_user_id)
|
|
|
|
logger.debug("ASFR: {}".format(user_auth))
|
|
|
|
page_data['servers'] = user_auth
|
2021-08-22 01:41:25 +02:00
|
|
|
|
2020-08-24 19:11:17 -04:00
|
|
|
for s in page_data['servers']:
|
|
|
|
try:
|
|
|
|
data = json.loads(s['int_ping_results'])
|
|
|
|
s['int_ping_results'] = data
|
|
|
|
except:
|
|
|
|
pass
|
2020-08-27 23:21:55 -04:00
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
template = "panel/dashboard.html"
|
|
|
|
|
2020-08-31 13:46:25 -04:00
|
|
|
elif page == 'server_detail':
|
2020-09-01 13:29:39 -04:00
|
|
|
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")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-09-01 13:29:39 -04:00
|
|
|
else:
|
|
|
|
# does this server id exist?
|
|
|
|
if not db_helper.server_id_exists(server_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-09-01 13:29:39 -04:00
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
if exec_user['superuser'] != 1:
|
2021-08-06 00:34:57 -04:00
|
|
|
if not db_helper.server_id_authorized(server_id, exec_user_id):
|
2021-08-22 12:14:31 +02:00
|
|
|
if not db_helper.server_id_authorized(int(server_id), exec_user_id):
|
2021-08-06 00:34:57 -04:00
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return False
|
2021-03-09 23:17:50 +01:00
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
valid_subpages = ['term', 'logs', 'backup', 'config', 'files', 'admin_controls']
|
2020-09-01 13:29:39 -04:00
|
|
|
|
|
|
|
if subpage not in valid_subpages:
|
2021-01-19 08:56:00 -05:00
|
|
|
logger.debug('not a valid subpage')
|
2020-09-01 13:29:39 -04:00
|
|
|
subpage = 'term'
|
2021-01-19 08:56:00 -05:00
|
|
|
logger.debug('Subpage: "{}"'.format(subpage))
|
2020-09-01 13:29:39 -04:00
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
server = self.controller.get_server_obj(server_id)
|
2020-09-01 13:29:39 -04:00
|
|
|
# server_data isn't needed since the server_stats also pulls server data
|
2021-03-21 23:02:18 -05:00
|
|
|
page_data['server_data'] = db_helper.get_server_data_by_id(server_id)
|
2020-09-01 13:29:39 -04:00
|
|
|
page_data['server_stats'] = db_helper.get_server_stats_by_id(server_id)
|
2021-03-21 23:02:18 -05:00
|
|
|
page_data['get_players'] = lambda: self.controller.stats.get_server_players(server_id)
|
2021-08-21 10:44:03 +02:00
|
|
|
page_data['active_link'] = subpage
|
|
|
|
page_data['permissions'] = {
|
2021-08-22 11:57:02 +02:00
|
|
|
'Commands': Enum_Permissions_Server.Commands,
|
|
|
|
'Terminal': Enum_Permissions_Server.Terminal,
|
|
|
|
'Logs': Enum_Permissions_Server.Logs,
|
|
|
|
'Schedule': Enum_Permissions_Server.Schedule,
|
|
|
|
'Backup': Enum_Permissions_Server.Backup,
|
|
|
|
'Files': Enum_Permissions_Server.Files,
|
|
|
|
'Config': Enum_Permissions_Server.Config,
|
|
|
|
'Players': Enum_Permissions_Server.Players,
|
2021-08-21 10:44:03 +02:00
|
|
|
}
|
|
|
|
page_data['user_permissions'] = self.controller.get_server_permissions_foruser(exec_user_id, server_id)
|
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
if subpage == "backup":
|
|
|
|
page_data['backup_config'] = db_helper.get_backup_config(server_id)
|
|
|
|
page_data['backup_list'] = server.list_backups()
|
2021-03-05 10:58:38 +02:00
|
|
|
|
|
|
|
def get_banned_players_html():
|
|
|
|
banned_players = helper.get_banned_players(server_id, db_helper)
|
|
|
|
if banned_players is None:
|
|
|
|
return """
|
|
|
|
<li class="playerItem banned">
|
|
|
|
<h3>Error while reading banned-players.json</h3>
|
|
|
|
</li>
|
|
|
|
"""
|
|
|
|
html = ""
|
|
|
|
for player in banned_players:
|
|
|
|
html += """
|
|
|
|
<li class="playerItem banned">
|
|
|
|
<h3>{}</h3>
|
|
|
|
<span>Banned by {} for reason: {}</span>
|
|
|
|
<button onclick="send_command_to_server('pardon {}')" type="button" class="btn btn-danger">Unban</button>
|
|
|
|
</li>
|
|
|
|
""".format(player['name'], player['source'], player['reason'], player['name'])
|
|
|
|
|
|
|
|
return html
|
|
|
|
if subpage == "admin_controls":
|
|
|
|
page_data['banned_players'] = get_banned_players_html()
|
2020-08-31 13:46:25 -04:00
|
|
|
|
2020-09-01 13:29:39 -04:00
|
|
|
# template = "panel/server_details.html"
|
|
|
|
template = "panel/server_{subpage}.html".format(subpage=subpage)
|
2020-08-31 13:46:25 -04:00
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
elif page == 'download_backup':
|
|
|
|
server_id = self.get_argument('id', None)
|
|
|
|
file = self.get_argument('file', "")
|
|
|
|
|
|
|
|
if server_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
else:
|
|
|
|
# does this server id exist?
|
|
|
|
if not db_helper.server_id_exists(server_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
if exec_user['superuser'] != 1:
|
|
|
|
#if not db_helper.server_id_authorized(server_id, exec_user_id):
|
2021-08-22 12:14:31 +02:00
|
|
|
if not db_helper.server_id_authorized(int(server_id), exec_user_id):
|
2021-03-21 23:44:22 -05:00
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
2021-07-30 19:20:01 +03:00
|
|
|
return
|
2021-03-21 23:02:18 -05:00
|
|
|
|
|
|
|
server_info = db_helper.get_server_data_by_id(server_id)
|
|
|
|
backup_file = os.path.abspath(os.path.join(server_info["backup_path"], file))
|
|
|
|
if not helper.in_path(server_info["backup_path"], backup_file) \
|
|
|
|
or not os.path.isfile(backup_file):
|
|
|
|
self.redirect("/panel/error?error=Invalid path detected")
|
|
|
|
return
|
|
|
|
|
|
|
|
self.set_header('Content-Type', 'application/octet-stream')
|
|
|
|
self.set_header('Content-Disposition', 'attachment; filename=' + file)
|
|
|
|
chunk_size = 1024 * 1024 * 4 # 4 MiB
|
|
|
|
|
|
|
|
with open(backup_file, 'rb') as f:
|
|
|
|
while True:
|
|
|
|
chunk = f.read(chunk_size)
|
|
|
|
if not chunk:
|
|
|
|
break
|
|
|
|
try:
|
|
|
|
self.write(chunk) # write the chunk to response
|
|
|
|
self.flush() # send the chunk to client
|
|
|
|
except iostream.StreamClosedError:
|
|
|
|
# this means the client has closed the connection
|
|
|
|
# so break the loop
|
|
|
|
break
|
|
|
|
finally:
|
|
|
|
# deleting the chunk is very important because
|
|
|
|
# if many clients are downloading files at the
|
|
|
|
# same time, the chunks in memory will keep
|
|
|
|
# increasing and will eat up the RAM
|
|
|
|
del chunk
|
|
|
|
self.redirect("/panel/server_detail?id={}&subpage=backup".format(server_id))
|
|
|
|
|
|
|
|
elif page == 'backup_now':
|
|
|
|
server_id = self.get_argument('id', None)
|
|
|
|
|
|
|
|
if server_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
else:
|
|
|
|
# does this server id exist?
|
|
|
|
if not db_helper.server_id_exists(server_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
if exec_user['superuser'] != 1:
|
|
|
|
#if not db_helper.server_id_authorized(server_id, exec_user_id):
|
2021-08-22 12:14:31 +02:00
|
|
|
if not db_helper.server_id_authorized(int(server_id), exec_user_id):
|
2021-03-21 23:44:22 -05:00
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
2021-07-30 19:20:01 +03:00
|
|
|
return
|
2021-03-21 23:02:18 -05:00
|
|
|
|
|
|
|
server = self.controller.get_server_obj(server_id).backup_server()
|
|
|
|
self.redirect("/panel/server_detail?id={}&subpage=backup".format(server_id))
|
|
|
|
|
2020-12-06 15:42:49 -05:00
|
|
|
elif page == 'panel_config':
|
2021-08-08 16:43:04 -04:00
|
|
|
auth_servers = {}
|
|
|
|
auth_role_servers = {}
|
2021-08-09 17:11:45 -04:00
|
|
|
users_list = []
|
|
|
|
role_users = {}
|
2021-08-08 16:43:04 -04:00
|
|
|
roles = db_helper.get_all_roles()
|
|
|
|
role_servers = []
|
|
|
|
user_roles = {}
|
|
|
|
for user in db_helper.get_all_users():
|
|
|
|
user_roles_list = db_helper.get_user_roles_names(user.user_id)
|
2021-08-22 18:50:30 +02:00
|
|
|
user_servers = db_helper.get_authorized_servers(user.user_id)
|
2021-08-08 16:43:04 -04:00
|
|
|
servers = []
|
|
|
|
for server in user_servers:
|
|
|
|
servers.append(server['server_name'])
|
|
|
|
new_item = {user.user_id: servers}
|
|
|
|
auth_servers.update(new_item)
|
|
|
|
data = {user.user_id: user_roles_list}
|
|
|
|
user_roles.update(data)
|
|
|
|
for role in roles:
|
2021-08-09 00:24:08 -04:00
|
|
|
role_servers = []
|
2021-08-08 16:43:04 -04:00
|
|
|
role = db_helper.get_role(role.role_id)
|
|
|
|
for serv_id in role['servers']:
|
|
|
|
role_servers.append(db_helper.get_server_data_by_id(serv_id)['server_name'])
|
|
|
|
data = {role['role_id']: role_servers}
|
|
|
|
auth_role_servers.update(data)
|
|
|
|
|
2021-08-09 17:11:45 -04:00
|
|
|
|
2021-08-08 16:43:04 -04:00
|
|
|
page_data['auth-servers'] = auth_servers
|
|
|
|
page_data['role-servers'] = auth_role_servers
|
|
|
|
page_data['user-roles'] = user_roles
|
|
|
|
|
2021-08-06 12:21:47 -04:00
|
|
|
if exec_user['superuser'] == 1:
|
|
|
|
page_data['users'] = db_helper.get_all_users()
|
|
|
|
page_data['roles'] = db_helper.get_all_roles()
|
|
|
|
else:
|
|
|
|
page_data['users'] = db_helper.user_query(exec_user['user_id'])
|
|
|
|
page_data['roles'] = db_helper.user_role_query(exec_user['user_id'])
|
2021-08-08 16:43:04 -04:00
|
|
|
|
2020-12-25 22:00:28 -05:00
|
|
|
for user in page_data['users']:
|
|
|
|
if user.user_id != exec_user['user_id']:
|
|
|
|
user.api_token = "********"
|
2020-12-06 15:42:49 -05:00
|
|
|
template = "panel/panel_config.html"
|
2020-08-31 13:46:25 -04:00
|
|
|
|
2020-12-24 17:55:15 -05:00
|
|
|
elif page == "add_user":
|
|
|
|
page_data['new_user'] = True
|
|
|
|
page_data['user'] = {}
|
|
|
|
page_data['user']['username'] = ""
|
|
|
|
page_data['user']['user_id'] = -1
|
|
|
|
page_data['user']['enabled'] = True
|
|
|
|
page_data['user']['superuser'] = False
|
2020-12-25 22:00:28 -05:00
|
|
|
page_data['user']['api_token'] = "N/A"
|
|
|
|
page_data['user']['created'] = "N/A"
|
|
|
|
page_data['user']['last_login'] = "N/A"
|
|
|
|
page_data['user']['last_ip'] = "N/A"
|
2021-03-09 23:17:50 +01:00
|
|
|
page_data['user']['last_update'] = "N/A"
|
2020-12-25 22:00:28 -05:00
|
|
|
page_data['user']['roles'] = set()
|
2020-12-27 11:00:26 -05:00
|
|
|
|
2021-08-24 23:07:00 +02:00
|
|
|
if Enum_Permissions_Crafty.User_Config not in exec_user_crafty_permissions:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a user editor")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
|
2020-12-24 17:55:15 -05:00
|
|
|
page_data['roles_all'] = db_helper.get_all_roles()
|
2021-04-03 12:36:01 -05:00
|
|
|
page_data['servers'] = []
|
2021-03-21 23:02:18 -05:00
|
|
|
page_data['servers_all'] = self.controller.list_defined_servers()
|
2021-08-09 01:44:16 -04:00
|
|
|
page_data['role-servers'] = []
|
2021-08-24 23:07:00 +02:00
|
|
|
page_data['permissions_all'] = self.controller.list_defined_crafty_permissions()
|
|
|
|
page_data['permissions_list'] = set()
|
|
|
|
page_data['quantity_server'] = self.controller.list_all_crafty_permissions_quantity_limits()
|
|
|
|
|
2020-12-24 17:55:15 -05:00
|
|
|
template = "panel/panel_edit_user.html"
|
|
|
|
|
|
|
|
elif page == "edit_user":
|
2020-12-27 11:00:26 -05:00
|
|
|
user_id = self.get_argument('id', None)
|
2021-08-22 18:50:30 +02:00
|
|
|
role_servers = db_helper.get_authorized_servers(user_id)
|
2021-08-08 18:26:28 -04:00
|
|
|
page_role_servers = []
|
2021-08-06 00:34:57 -04:00
|
|
|
servers = set()
|
2021-08-08 18:26:28 -04:00
|
|
|
for server in role_servers:
|
|
|
|
page_role_servers.append(server['server_id'])
|
2021-08-06 00:34:57 -04:00
|
|
|
page_data['new_user'] = False
|
2020-12-27 11:00:26 -05:00
|
|
|
page_data['user'] = db_helper.get_user(user_id)
|
2021-08-06 00:34:57 -04:00
|
|
|
page_data['servers'] = servers
|
2021-08-08 18:26:28 -04:00
|
|
|
page_data['role-servers'] = page_role_servers
|
2020-12-24 17:55:15 -05:00
|
|
|
page_data['roles_all'] = db_helper.get_all_roles()
|
2021-03-21 23:02:18 -05:00
|
|
|
page_data['servers_all'] = self.controller.list_defined_servers()
|
2021-08-24 23:07:00 +02:00
|
|
|
page_data['permissions_all'] = self.controller.list_defined_crafty_permissions()
|
2021-09-06 19:27:01 +02:00
|
|
|
page_data['permissions_list'] = self.controller.crafty_perms.get_crafty_permissions_list(user_id)
|
2021-08-24 23:07:00 +02:00
|
|
|
page_data['quantity_server'] = self.controller.list_crafty_permissions_quantity_limits(user_id)
|
2020-12-25 22:00:28 -05:00
|
|
|
|
2021-08-09 17:11:45 -04:00
|
|
|
if user_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid User ID")
|
|
|
|
return
|
2021-08-24 23:07:00 +02:00
|
|
|
elif Enum_Permissions_Crafty.User_Config not in exec_user_crafty_permissions:
|
|
|
|
if user_id != exec_user_id:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a user editor")
|
|
|
|
return
|
|
|
|
|
2021-08-09 01:29:13 -04:00
|
|
|
page_data['servers'] = []
|
|
|
|
page_data['role-servers'] = []
|
|
|
|
page_data['roles_all'] = []
|
|
|
|
page_data['servers_all'] = []
|
2020-12-27 11:00:26 -05:00
|
|
|
|
2020-12-25 22:00:28 -05:00
|
|
|
if exec_user['user_id'] != page_data['user']['user_id']:
|
|
|
|
page_data['user']['api_token'] = "********"
|
2020-12-24 17:55:15 -05:00
|
|
|
template = "panel/panel_edit_user.html"
|
|
|
|
|
|
|
|
elif page == "remove_user":
|
|
|
|
user_id = bleach.clean(self.get_argument('id', None))
|
|
|
|
|
|
|
|
if not exec_user['superuser']:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not superuser")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
elif user_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid User ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
else:
|
|
|
|
# does this user id exist?
|
|
|
|
target_user = db_helper.get_user(user_id)
|
|
|
|
if not target_user:
|
|
|
|
self.redirect("/panel/error?error=Invalid User ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
elif target_user['superuser']:
|
|
|
|
self.redirect("/panel/error?error=Cannot remove a superuser")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
|
|
|
|
db_helper.remove_user(user_id)
|
|
|
|
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
|
|
|
"Removed user {} (UID:{})".format(target_user['username'], user_id),
|
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
|
|
|
self.redirect("/panel/panel_config")
|
|
|
|
|
2020-12-27 11:00:26 -05:00
|
|
|
elif page == "add_role":
|
2021-08-09 17:18:02 -04:00
|
|
|
user_roles = {}
|
|
|
|
for user in db_helper.get_all_users():
|
|
|
|
user_roles_list = db_helper.get_user_roles_names(user.user_id)
|
2021-08-22 18:50:30 +02:00
|
|
|
user_servers = db_helper.get_authorized_servers(user.user_id)
|
2021-08-09 17:18:02 -04:00
|
|
|
data = {user.user_id: user_roles_list}
|
|
|
|
user_roles.update(data)
|
2020-12-27 11:00:26 -05:00
|
|
|
page_data['new_role'] = True
|
|
|
|
page_data['role'] = {}
|
|
|
|
page_data['role']['role_name'] = ""
|
|
|
|
page_data['role']['role_id'] = -1
|
|
|
|
page_data['role']['created'] = "N/A"
|
|
|
|
page_data['role']['last_update'] = "N/A"
|
|
|
|
page_data['role']['servers'] = set()
|
2021-08-09 17:18:02 -04:00
|
|
|
page_data['user-roles'] = user_roles
|
|
|
|
page_data['users'] = db_helper.get_all_users()
|
2020-12-27 11:00:26 -05:00
|
|
|
|
2021-08-24 23:07:00 +02:00
|
|
|
if Enum_Permissions_Crafty.Roles_Config not in exec_user_crafty_permissions:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a role editor")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
page_data['servers_all'] = self.controller.list_defined_servers()
|
2021-08-20 00:18:50 +02:00
|
|
|
page_data['permissions_all'] = self.controller.list_defined_permissions()
|
|
|
|
page_data['permissions_list'] = set()
|
2020-12-27 11:00:26 -05:00
|
|
|
template = "panel/panel_edit_role.html"
|
|
|
|
|
|
|
|
elif page == "edit_role":
|
2021-08-09 17:11:45 -04:00
|
|
|
auth_servers = {}
|
|
|
|
|
|
|
|
user_roles = {}
|
|
|
|
for user in db_helper.get_all_users():
|
|
|
|
user_roles_list = db_helper.get_user_roles_names(user.user_id)
|
2021-08-22 18:50:30 +02:00
|
|
|
user_servers = db_helper.get_authorized_servers(user.user_id)
|
2021-08-09 17:11:45 -04:00
|
|
|
data = {user.user_id: user_roles_list}
|
|
|
|
user_roles.update(data)
|
2020-12-27 11:00:26 -05:00
|
|
|
page_data['new_role'] = False
|
|
|
|
role_id = self.get_argument('id', None)
|
|
|
|
page_data['role'] = db_helper.get_role(role_id)
|
2021-03-21 23:02:18 -05:00
|
|
|
page_data['servers_all'] = self.controller.list_defined_servers()
|
2021-08-20 00:18:50 +02:00
|
|
|
page_data['permissions_all'] = self.controller.list_defined_permissions()
|
|
|
|
page_data['permissions_list'] = self.controller.get_role_permissions(role_id)
|
2021-08-09 17:11:45 -04:00
|
|
|
page_data['user-roles'] = user_roles
|
|
|
|
page_data['users'] = db_helper.get_all_users()
|
2020-12-27 11:00:26 -05:00
|
|
|
|
2021-08-24 23:07:00 +02:00
|
|
|
if Enum_Permissions_Crafty.Roles_Config not in exec_user_crafty_permissions:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a role editor")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
elif role_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Role ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
template = "panel/panel_edit_role.html"
|
|
|
|
|
|
|
|
elif page == "remove_role":
|
|
|
|
role_id = bleach.clean(self.get_argument('id', None))
|
|
|
|
|
|
|
|
if not exec_user['superuser']:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not superuser")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
elif role_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Role ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
else:
|
|
|
|
# does this user id exist?
|
2021-04-03 13:18:43 -05:00
|
|
|
target_role = db_helper.get_role(role_id)
|
2020-12-27 11:00:26 -05:00
|
|
|
if not target_role:
|
|
|
|
self.redirect("/panel/error?error=Invalid Role ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
db_helper.remove_role(role_id)
|
|
|
|
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
|
|
|
"Removed role {} (RID:{})".format(target_role['role_name'], role_id),
|
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
|
|
|
self.redirect("/panel/panel_config")
|
|
|
|
|
2020-12-13 13:40:55 -05:00
|
|
|
elif page == "activity_logs":
|
|
|
|
page_data['audit_logs'] = db_helper.get_actity_log()
|
|
|
|
|
|
|
|
template = "panel/activity_logs.html"
|
|
|
|
|
2021-08-24 21:33:29 -04:00
|
|
|
elif page == 'download_file':
|
|
|
|
server_id = self.get_argument('id', None)
|
|
|
|
file = self.get_argument('path', "")
|
|
|
|
name = self.get_argument('name', "")
|
|
|
|
|
|
|
|
if server_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
else:
|
|
|
|
# does this server id exist?
|
|
|
|
if not db_helper.server_id_exists(server_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
|
|
|
|
if exec_user['superuser'] != 1:
|
|
|
|
#if not db_helper.server_id_authorized(server_id, exec_user_id):
|
|
|
|
if not db_helper.server_id_authorized(int(server_id), exec_user_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
|
|
|
|
server_info = db_helper.get_server_data_by_id(server_id)
|
|
|
|
|
|
|
|
if not helper.in_path(server_info["path"], file) \
|
|
|
|
or not os.path.isfile(file):
|
|
|
|
self.redirect("/panel/error?error=Invalid path detected")
|
|
|
|
return
|
|
|
|
|
|
|
|
self.set_header('Content-Type', 'application/octet-stream')
|
|
|
|
self.set_header('Content-Disposition', 'attachment; filename=' + name)
|
|
|
|
chunk_size = 1024 * 1024 * 4 # 4 MiB
|
|
|
|
|
|
|
|
with open(file, 'rb') as f:
|
|
|
|
while True:
|
|
|
|
chunk = f.read(chunk_size)
|
|
|
|
if not chunk:
|
|
|
|
break
|
|
|
|
try:
|
|
|
|
self.write(chunk) # write the chunk to response
|
|
|
|
self.flush() # send the chunk to client
|
|
|
|
except iostream.StreamClosedError:
|
|
|
|
# this means the client has closed the connection
|
|
|
|
# so break the loop
|
|
|
|
break
|
|
|
|
finally:
|
|
|
|
# deleting the chunk is very important because
|
|
|
|
# if many clients are downloading files at the
|
|
|
|
# same time, the chunks in memory will keep
|
|
|
|
# increasing and will eat up the RAM
|
|
|
|
del chunk
|
|
|
|
self.redirect("/panel/server_detail?id={}&subpage=files".format(server_id))
|
|
|
|
|
|
|
|
|
2020-08-13 10:38:36 -04:00
|
|
|
self.render(
|
|
|
|
template,
|
2020-12-16 01:17:41 +02:00
|
|
|
data=page_data,
|
|
|
|
time=time,
|
|
|
|
utc_offset=(time.timezone * -1 / 60 / 60),
|
2021-03-26 15:57:50 +02:00
|
|
|
translate=self.translator.translate,
|
2020-08-24 13:08:17 -04:00
|
|
|
)
|
2020-09-04 12:35:06 -04:00
|
|
|
|
|
|
|
@tornado.web.authenticated
|
|
|
|
def post(self, page):
|
2021-04-03 12:36:01 -05:00
|
|
|
exec_user_data = json.loads(self.get_secure_cookie("user_data"))
|
|
|
|
exec_user_id = exec_user_data['user_id']
|
|
|
|
exec_user = db_helper.get_user(exec_user_id)
|
|
|
|
|
|
|
|
exec_user_role = set()
|
|
|
|
if exec_user['superuser'] == 1:
|
|
|
|
defined_servers = self.controller.list_defined_servers()
|
|
|
|
exec_user_role.add("Super User")
|
2021-08-24 23:07:00 +02:00
|
|
|
exec_user_crafty_permissions = self.controller.list_defined_crafty_permissions()
|
2021-04-03 12:36:01 -05:00
|
|
|
else:
|
2021-09-06 19:27:01 +02:00
|
|
|
exec_user_crafty_permissions = self.controller.crafty_perms.get_crafty_permissions_list(exec_user_id)
|
2021-04-03 12:36:01 -05:00
|
|
|
defined_servers = self.controller.list_authorized_servers(exec_user_id)
|
|
|
|
for r in exec_user['roles']:
|
|
|
|
role = db_helper.get_role(r)
|
|
|
|
exec_user_role.add(role['role_name'])
|
2020-09-04 12:35:06 -04:00
|
|
|
|
|
|
|
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)
|
2020-09-04 14:05:42 -04:00
|
|
|
auto_start_delay = self.get_argument('auto_start_delay', '10')
|
2020-09-22 12:11:16 -04:00
|
|
|
server_ip = self.get_argument('server_ip', None)
|
2020-09-04 12:35:06 -04:00
|
|
|
server_port = self.get_argument('server_port', None)
|
2021-07-24 21:09:39 -04:00
|
|
|
executable_update_url = self.get_argument('executable_update_url', None)
|
2020-09-04 14:05:42 -04:00
|
|
|
auto_start = int(float(self.get_argument('auto_start', '0')))
|
|
|
|
crash_detection = int(float(self.get_argument('crash_detection', '0')))
|
2021-01-20 17:20:42 +02:00
|
|
|
logs_delete_after = int(float(self.get_argument('logs_delete_after', '0')))
|
2020-09-04 12:35:06 -04:00
|
|
|
subpage = self.get_argument('subpage', None)
|
|
|
|
|
2021-03-06 14:48:02 -06:00
|
|
|
if not exec_user['superuser']:
|
2021-08-06 00:34:57 -04:00
|
|
|
if not db_helper.server_id_authorized(server_id, exec_user_id):
|
2021-08-22 12:14:31 +02:00
|
|
|
self.redirect("/panel/error?error=Unauthorized access: invalid server id")
|
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
elif server_id is None:
|
2020-09-04 12:35:06 -04:00
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-09-04 12:35:06 -04:00
|
|
|
else:
|
|
|
|
# does this server id exist?
|
|
|
|
if not db_helper.server_id_exists(server_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-09-04 12:35:06 -04:00
|
|
|
|
|
|
|
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,
|
2020-09-22 12:11:16 -04:00
|
|
|
Servers.server_ip: server_ip,
|
2020-09-04 12:35:06 -04:00
|
|
|
Servers.server_port: server_port,
|
|
|
|
Servers.auto_start: auto_start,
|
2021-07-24 21:09:39 -04:00
|
|
|
Servers.executable_update_url: executable_update_url,
|
2020-09-04 12:35:06 -04:00
|
|
|
Servers.crash_detection: crash_detection,
|
2021-01-20 17:20:42 +02:00
|
|
|
Servers.logs_delete_after: logs_delete_after,
|
2020-09-04 12:35:06 -04:00
|
|
|
}).where(Servers.server_id == server_id).execute()
|
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
self.controller.refresh_server_settings(server_id)
|
2020-10-07 09:19:47 -04:00
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
2020-09-04 14:05:42 -04:00
|
|
|
"Edited server {} named {}".format(server_id, server_name),
|
|
|
|
server_id,
|
|
|
|
self.get_remote_ip())
|
|
|
|
|
2020-09-04 12:35:06 -04:00
|
|
|
self.redirect("/panel/server_detail?id={}&subpage=config".format(server_id))
|
2020-12-24 17:55:15 -05:00
|
|
|
|
2021-03-21 23:02:18 -05:00
|
|
|
if page == "server_backup":
|
|
|
|
logger.debug(self.request.arguments)
|
|
|
|
server_id = self.get_argument('id', None)
|
|
|
|
backup_path = bleach.clean(self.get_argument('backup_path', None))
|
|
|
|
max_backups = bleach.clean(self.get_argument('max_backups', None))
|
|
|
|
enabled = int(float(bleach.clean(self.get_argument('auto_enabled'), '0')))
|
|
|
|
|
|
|
|
if not exec_user['superuser']:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not superuser")
|
|
|
|
return
|
|
|
|
elif server_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
else:
|
|
|
|
# does this server id exist?
|
|
|
|
if not db_helper.server_id_exists(server_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Server ID")
|
|
|
|
return
|
|
|
|
|
|
|
|
if backup_path is not None:
|
|
|
|
Servers.update({
|
|
|
|
Servers.backup_path: backup_path
|
|
|
|
}).where(Servers.server_id == server_id).execute()
|
|
|
|
db_helper.set_backup_config(server_id, max_backups=max_backups)
|
|
|
|
|
2021-04-03 12:36:01 -05:00
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
2021-03-21 23:02:18 -05:00
|
|
|
"Edited server {}: updated backups".format(server_id),
|
|
|
|
server_id,
|
|
|
|
self.get_remote_ip())
|
|
|
|
self.tasks_manager.reload_schedule_from_db()
|
|
|
|
self.redirect("/panel/server_detail?id={}&subpage=backup".format(server_id))
|
|
|
|
|
2020-12-24 17:55:15 -05:00
|
|
|
elif page == "edit_user":
|
|
|
|
user_id = bleach.clean(self.get_argument('id', None))
|
|
|
|
username = bleach.clean(self.get_argument('username', None))
|
|
|
|
password0 = bleach.clean(self.get_argument('password0', None))
|
|
|
|
password1 = bleach.clean(self.get_argument('password1', None))
|
2021-04-04 21:22:52 +03:00
|
|
|
enabled = int(float(self.get_argument('enabled', '0')))
|
|
|
|
regen_api = int(float(self.get_argument('regen_api', '0')))
|
2020-12-24 17:55:15 -05:00
|
|
|
|
2021-08-24 23:07:00 +02:00
|
|
|
if Enum_Permissions_Crafty.User_Config not in exec_user_crafty_permissions:
|
|
|
|
if user_id != exec_user_id:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a user editor")
|
|
|
|
return
|
|
|
|
|
2021-08-09 01:29:13 -04:00
|
|
|
user_data = {
|
|
|
|
"username": username,
|
|
|
|
"password": password0,
|
|
|
|
}
|
|
|
|
db_helper.update_user(user_id, user_data=user_data)
|
|
|
|
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
|
|
|
"Edited user {} (UID:{}) password".format(username,
|
|
|
|
user_id),
|
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
|
|
|
self.redirect("/panel/panel_config")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
elif username is None or username == "":
|
|
|
|
self.redirect("/panel/error?error=Invalid username")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
elif user_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid User ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
else:
|
|
|
|
# does this user id exist?
|
|
|
|
if not db_helper.user_id_exists(user_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid User ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
|
|
|
|
if password0 != password1:
|
|
|
|
self.redirect("/panel/error?error=Passwords must match")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
|
2020-12-25 22:00:28 -05:00
|
|
|
roles = set()
|
2020-12-27 11:00:26 -05:00
|
|
|
for role in db_helper.get_all_roles():
|
2020-12-25 22:00:28 -05:00
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
2020-12-27 11:00:26 -05:00
|
|
|
self.get_argument('role_{}_membership'.format(role.role_id), '0')
|
2020-12-25 22:00:28 -05:00
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
2020-12-27 11:00:26 -05:00
|
|
|
roles.add(role.role_id)
|
2020-12-25 22:00:28 -05:00
|
|
|
|
2021-08-25 20:22:43 +02:00
|
|
|
permissions_mask = "000"
|
2021-08-24 23:07:00 +02:00
|
|
|
server_quantity = {}
|
|
|
|
for permission in self.controller.list_defined_crafty_permissions():
|
2021-08-06 00:34:57 -04:00
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
2021-08-24 23:07:00 +02:00
|
|
|
self.get_argument('permission_{}'.format(permission.name), '0')
|
2021-08-06 00:34:57 -04:00
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
2021-08-24 23:07:00 +02:00
|
|
|
permissions_mask = crafty_permissions.set_permission(permissions_mask, permission, argument)
|
|
|
|
|
|
|
|
q_argument = int(float(
|
|
|
|
bleach.clean(
|
|
|
|
self.get_argument('quantity_{}'.format(permission.name), '0')
|
|
|
|
)
|
|
|
|
))
|
|
|
|
if q_argument:
|
|
|
|
server_quantity[permission.name] = q_argument
|
2021-08-24 19:19:33 -04:00
|
|
|
else:
|
|
|
|
server_quantity[permission.name] = 0
|
|
|
|
|
2020-12-24 17:55:15 -05:00
|
|
|
user_data = {
|
|
|
|
"username": username,
|
|
|
|
"password": password0,
|
|
|
|
"enabled": enabled,
|
|
|
|
"regen_api": regen_api,
|
2020-12-25 22:00:28 -05:00
|
|
|
"roles": roles,
|
2020-12-24 17:55:15 -05:00
|
|
|
}
|
2021-08-24 23:07:00 +02:00
|
|
|
user_crafty_data = {
|
|
|
|
"permissions_mask": permissions_mask,
|
|
|
|
"server_quantity": server_quantity
|
|
|
|
}
|
|
|
|
db_helper.update_user(user_id, user_data=user_data, user_crafty_data=user_crafty_data)
|
2020-12-24 17:55:15 -05:00
|
|
|
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
2021-08-24 23:07:00 +02:00
|
|
|
"Edited user {} (UID:{}) with roles {} and permissions {}".format(username, user_id, roles, permissions_mask),
|
2020-12-24 17:55:15 -05:00
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
|
|
|
self.redirect("/panel/panel_config")
|
|
|
|
|
|
|
|
|
|
|
|
elif page == "add_user":
|
|
|
|
username = bleach.clean(self.get_argument('username', None))
|
|
|
|
password0 = bleach.clean(self.get_argument('password0', None))
|
|
|
|
password1 = bleach.clean(self.get_argument('password1', None))
|
2021-04-04 21:22:52 +03:00
|
|
|
enabled = int(float(self.get_argument('enabled', '0')))
|
2020-12-24 17:55:15 -05:00
|
|
|
|
2021-08-24 23:07:00 +02:00
|
|
|
if Enum_Permissions_Crafty.User_Config not in exec_user_crafty_permissions:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a user editor")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
elif username is None or username == "":
|
|
|
|
self.redirect("/panel/error?error=Invalid username")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
else:
|
|
|
|
# does this user id exist?
|
2021-04-04 21:22:52 +03:00
|
|
|
if db_helper.get_user_id_by_name(username) is not None:
|
2020-12-24 17:55:15 -05:00
|
|
|
self.redirect("/panel/error?error=User exists")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
|
|
|
|
if password0 != password1:
|
|
|
|
self.redirect("/panel/error?error=Passwords must match")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-24 17:55:15 -05:00
|
|
|
|
2020-12-25 22:00:28 -05:00
|
|
|
roles = set()
|
2020-12-27 11:00:26 -05:00
|
|
|
for role in db_helper.get_all_roles():
|
2020-12-25 22:00:28 -05:00
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
2020-12-27 11:00:26 -05:00
|
|
|
self.get_argument('role_{}_membership'.format(role.role_id), '0')
|
2020-12-25 22:00:28 -05:00
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
2021-04-03 13:18:43 -05:00
|
|
|
roles.add(role.role_id)
|
2021-08-24 23:07:00 +02:00
|
|
|
|
2021-08-25 20:22:43 +02:00
|
|
|
permissions_mask = "000"
|
2021-08-24 23:07:00 +02:00
|
|
|
server_quantity = {}
|
|
|
|
for permission in self.controller.list_defined_crafty_permissions():
|
2020-12-25 22:00:28 -05:00
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
2021-08-24 23:07:00 +02:00
|
|
|
self.get_argument('permission_{}'.format(permission.name), '0')
|
2020-12-25 22:00:28 -05:00
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
2021-08-24 23:07:00 +02:00
|
|
|
permissions_mask = crafty_permissions.set_permission(permissions_mask, permission, argument)
|
|
|
|
|
|
|
|
q_argument = int(float(
|
|
|
|
bleach.clean(
|
|
|
|
self.get_argument('quantity_{}'.format(permission.name), '0')
|
|
|
|
)
|
|
|
|
))
|
|
|
|
if q_argument:
|
|
|
|
server_quantity[permission.name] = q_argument
|
2021-08-24 19:25:35 -04:00
|
|
|
else:
|
|
|
|
server_quantity[permission.name] = 0
|
|
|
|
|
2020-12-24 17:55:15 -05:00
|
|
|
user_id = db_helper.add_user(username, password=password0, enabled=enabled)
|
2021-08-06 00:34:57 -04:00
|
|
|
user_data = {
|
|
|
|
"roles": roles,
|
|
|
|
}
|
2021-08-24 23:07:00 +02:00
|
|
|
user_crafty_data = {
|
|
|
|
"permissions_mask": permissions_mask,
|
|
|
|
"server_quantity": server_quantity
|
|
|
|
}
|
|
|
|
db_helper.update_user(user_id, user_data=user_data, user_crafty_data=user_crafty_data)
|
2020-12-24 17:55:15 -05:00
|
|
|
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
|
|
|
"Added user {} (UID:{})".format(username, user_id),
|
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
2021-04-03 12:36:01 -05:00
|
|
|
"Edited user {} (UID:{}) with roles {}".format(username, user_id, roles),
|
2020-12-24 17:55:15 -05:00
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
2020-12-27 11:00:26 -05:00
|
|
|
self.redirect("/panel/panel_config")
|
|
|
|
|
|
|
|
elif page == "edit_role":
|
|
|
|
role_id = bleach.clean(self.get_argument('id', None))
|
|
|
|
role_name = bleach.clean(self.get_argument('role_name', None))
|
|
|
|
|
2021-08-24 23:07:00 +02:00
|
|
|
if Enum_Permissions_Crafty.Roles_Config not in exec_user_crafty_permissions:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a role editor")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
elif role_name is None or role_name == "":
|
|
|
|
self.redirect("/panel/error?error=Invalid username")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
elif role_id is None:
|
|
|
|
self.redirect("/panel/error?error=Invalid Role ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
else:
|
|
|
|
# does this user id exist?
|
|
|
|
if not db_helper.role_id_exists(role_id):
|
|
|
|
self.redirect("/panel/error?error=Invalid Role ID")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
servers = set()
|
2021-03-21 23:02:18 -05:00
|
|
|
for server in self.controller.list_defined_servers():
|
2020-12-27 11:00:26 -05:00
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
|
|
|
self.get_argument('server_{}_access'.format(server['server_id']), '0')
|
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
|
|
|
servers.add(server['server_id'])
|
2021-08-20 00:18:50 +02:00
|
|
|
|
|
|
|
permissions_mask = "00000000"
|
|
|
|
for permission in self.controller.list_defined_permissions():
|
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
|
|
|
self.get_argument('permission_{}'.format(permission.name), '0')
|
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
2021-08-22 11:57:02 +02:00
|
|
|
permissions_mask = server_permissions.set_permission(permissions_mask, permission, argument)
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
role_data = {
|
|
|
|
"role_name": role_name,
|
|
|
|
"servers": servers
|
|
|
|
}
|
2021-08-20 00:18:50 +02:00
|
|
|
db_helper.update_role(role_id, role_data=role_data, permissions_mask=permissions_mask)
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
|
|
|
"Edited role {} (RID:{}) with servers {}".format(role_name, role_id, servers),
|
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
|
|
|
self.redirect("/panel/panel_config")
|
|
|
|
|
|
|
|
|
|
|
|
elif page == "add_role":
|
|
|
|
role_name = bleach.clean(self.get_argument('role_name', None))
|
|
|
|
|
2021-08-24 23:07:00 +02:00
|
|
|
if Enum_Permissions_Crafty.Roles_Config not in exec_user_crafty_permissions:
|
|
|
|
self.redirect("/panel/error?error=Unauthorized access: not a role editor")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
elif role_name is None or role_name == "":
|
|
|
|
self.redirect("/panel/error?error=Invalid role name")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
else:
|
|
|
|
# does this user id exist?
|
|
|
|
if db_helper.get_roleid_by_name(role_name) is not None:
|
|
|
|
self.redirect("/panel/error?error=Role exists")
|
2021-03-21 23:02:18 -05:00
|
|
|
return
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
servers = set()
|
2021-03-21 23:02:18 -05:00
|
|
|
for server in self.controller.list_defined_servers():
|
2020-12-27 11:00:26 -05:00
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
|
|
|
self.get_argument('server_{}_access'.format(server['server_id']), '0')
|
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
|
|
|
servers.add(server['server_id'])
|
2021-08-20 00:18:50 +02:00
|
|
|
|
|
|
|
permissions_mask = "00000000"
|
|
|
|
for permission in self.controller.list_defined_permissions():
|
|
|
|
argument = int(float(
|
|
|
|
bleach.clean(
|
|
|
|
self.get_argument('permission_{}'.format(permission.name), '0')
|
|
|
|
)
|
|
|
|
))
|
|
|
|
if argument:
|
2021-08-22 11:57:02 +02:00
|
|
|
permissions_mask = server_permissions.set_permission(permissions_mask, permission, argument)
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
role_id = db_helper.add_role(role_name)
|
2021-08-20 00:18:50 +02:00
|
|
|
db_helper.update_role(role_id, {"servers": servers}, permissions_mask)
|
2020-12-27 11:00:26 -05:00
|
|
|
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
|
|
|
"Added role {} (RID:{})".format(role_name, role_id),
|
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
|
|
|
db_helper.add_to_audit_log(exec_user['user_id'],
|
|
|
|
"Edited role {} (RID:{}) with servers {}".format(role_name, role_id, servers),
|
|
|
|
server_id=0,
|
|
|
|
source_ip=self.get_remote_ip())
|
2021-03-06 14:48:02 -06:00
|
|
|
self.redirect("/panel/panel_config")
|
2021-03-21 23:02:18 -05:00
|
|
|
|
|
|
|
else:
|
|
|
|
self.set_status(404)
|
2021-03-26 15:57:50 +02:00
|
|
|
self.render(
|
|
|
|
"public/404.html",
|
|
|
|
translate=self.translator.translate,
|
|
|
|
)
|