2021-09-09 00:01:10 +02:00
|
|
|
import logging
|
2023-01-19 11:27:33 -05:00
|
|
|
import queue
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2023-10-07 23:50:56 +02:00
|
|
|
from prometheus_client import CollectorRegistry, Gauge
|
|
|
|
|
2023-06-03 15:05:08 -04:00
|
|
|
from app.classes.models.management import HelpersManagement, HelpersWebhooks
|
2022-04-14 03:10:25 +01:00
|
|
|
from app.classes.models.servers import HelperServers
|
2021-09-09 00:01:10 +02:00
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
|
2022-04-14 03:10:25 +01:00
|
|
|
class ManagementController:
|
2022-04-11 00:23:55 -05:00
|
|
|
def __init__(self, management_helper):
|
|
|
|
self.management_helper = management_helper
|
2023-01-19 11:27:33 -05:00
|
|
|
self.command_queue = queue.Queue()
|
2023-10-07 23:50:56 +02:00
|
|
|
self.host_registry = CollectorRegistry()
|
|
|
|
self.init_host_registries()
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2023-01-17 20:40:16 +01:00
|
|
|
# **********************************************************************************
|
|
|
|
# Config Methods
|
|
|
|
# **********************************************************************************
|
|
|
|
@staticmethod
|
|
|
|
def set_login_image(path):
|
|
|
|
HelpersManagement.set_login_image(path)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_login_image():
|
|
|
|
return HelpersManagement.get_login_image()
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def set_login_opacity(opacity):
|
|
|
|
return HelpersManagement.set_login_opacity(opacity)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_login_opacity():
|
|
|
|
return HelpersManagement.get_login_opacity()
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
# Host_Stats Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
@staticmethod
|
|
|
|
def get_latest_hosts_stats():
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_latest_hosts_stats()
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-06-20 19:26:21 +00:00
|
|
|
@staticmethod
|
|
|
|
def set_crafty_api_key(key):
|
|
|
|
HelpersManagement.set_secret_api_key(key)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_crafty_api_key():
|
|
|
|
return HelpersManagement.get_secret_api_key()
|
|
|
|
|
2023-01-29 16:54:02 -05:00
|
|
|
@staticmethod
|
|
|
|
def set_cookie_secret(key):
|
|
|
|
HelpersManagement.set_cookie_secret(key)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def add_crafty_row():
|
|
|
|
HelpersManagement.create_crafty_row()
|
|
|
|
|
2023-10-07 23:50:56 +02:00
|
|
|
def init_host_registries(self):
|
|
|
|
# REGISTRY Entries for Server Stats functions
|
|
|
|
self.cpu_usage = Gauge(
|
|
|
|
name="CPU_Usage",
|
|
|
|
documentation="The CPU usage of the server",
|
|
|
|
registry=self.host_registry,
|
|
|
|
)
|
|
|
|
self.mem_usage_percent = Gauge(
|
|
|
|
name="Mem_Usage",
|
|
|
|
documentation="The Memory usage of the server",
|
|
|
|
registry=self.host_registry,
|
|
|
|
)
|
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
# Commands Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-04-11 00:23:55 -05:00
|
|
|
def send_command(self, user_id, server_id, remote_ip, command):
|
2022-04-14 03:10:25 +01:00
|
|
|
server_name = HelperServers.get_server_friendly_name(server_id)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
|
|
|
# Example: Admin issued command start_server for server Survival
|
2022-04-11 00:23:55 -05:00
|
|
|
self.management_helper.add_to_audit_log(
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id,
|
|
|
|
f"issued command {command} for server {server_name}",
|
|
|
|
server_id,
|
|
|
|
remote_ip,
|
|
|
|
)
|
2023-01-19 11:27:33 -05:00
|
|
|
self.queue_command(
|
|
|
|
{"server_id": server_id, "user_id": user_id, "command": command}
|
|
|
|
)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2023-01-19 11:27:33 -05:00
|
|
|
def queue_command(self, command_data):
|
|
|
|
self.command_queue.put(command_data)
|
2022-01-26 01:45:30 +00:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
# Audit_Log Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
@staticmethod
|
2023-08-20 17:01:32 -04:00
|
|
|
def get_activity_log():
|
|
|
|
return HelpersManagement.get_activity_log()
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-04-11 00:23:55 -05:00
|
|
|
def add_to_audit_log(self, user_id, log_msg, server_id=None, source_ip=None):
|
|
|
|
return self.management_helper.add_to_audit_log(
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id, log_msg, server_id, source_ip
|
|
|
|
)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-04-11 00:23:55 -05:00
|
|
|
def add_to_audit_log_raw(self, user_name, user_id, server_id, log_msg, source_ip):
|
|
|
|
return self.management_helper.add_to_audit_log_raw(
|
2022-03-23 02:50:12 +00:00
|
|
|
user_name, user_id, server_id, log_msg, source_ip
|
|
|
|
)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
# Schedules Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2022-03-23 02:50:12 +00:00
|
|
|
@staticmethod
|
|
|
|
def create_scheduled_task(
|
|
|
|
server_id,
|
|
|
|
action,
|
|
|
|
interval,
|
|
|
|
interval_type,
|
|
|
|
start_time,
|
|
|
|
command,
|
2022-08-05 13:52:50 -04:00
|
|
|
name,
|
2022-03-23 02:50:12 +00:00
|
|
|
enabled=True,
|
2023-01-16 11:20:15 -05:00
|
|
|
one_time=False,
|
|
|
|
cron_string="* * * * *",
|
|
|
|
parent=None,
|
|
|
|
delay=0,
|
2022-03-23 02:50:12 +00:00
|
|
|
):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.create_scheduled_task(
|
2022-03-23 02:50:12 +00:00
|
|
|
server_id,
|
|
|
|
action,
|
|
|
|
interval,
|
|
|
|
interval_type,
|
|
|
|
start_time,
|
|
|
|
command,
|
2022-08-05 13:52:50 -04:00
|
|
|
name,
|
2022-03-23 02:50:12 +00:00
|
|
|
enabled,
|
2023-01-16 15:16:43 -05:00
|
|
|
one_time,
|
|
|
|
cron_string,
|
|
|
|
parent,
|
|
|
|
delay,
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def delete_scheduled_task(schedule_id):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.delete_scheduled_task(schedule_id)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-11-09 14:13:35 -05:00
|
|
|
@staticmethod
|
2021-09-09 00:01:10 +02:00
|
|
|
def update_scheduled_task(schedule_id, updates):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.update_scheduled_task(schedule_id, updates)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_scheduled_task(schedule_id):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_scheduled_task(schedule_id)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-01-11 17:24:05 -05:00
|
|
|
@staticmethod
|
|
|
|
def get_scheduled_task_model(schedule_id):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_scheduled_task_model(schedule_id)
|
2022-01-11 17:24:05 -05:00
|
|
|
|
2022-02-25 19:53:38 -05:00
|
|
|
@staticmethod
|
|
|
|
def get_child_schedules(sch_id):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_child_schedules(sch_id)
|
2022-02-25 19:53:38 -05:00
|
|
|
|
2021-09-09 00:01:10 +02:00
|
|
|
@staticmethod
|
|
|
|
def get_schedules_by_server(server_id):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_schedules_by_server(server_id)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_schedules_all():
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_schedules_all()
|
2021-09-09 00:01:10 +02:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_schedules_enabled():
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_schedules_enabled()
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
# Backups Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-09 00:01:10 +02:00
|
|
|
@staticmethod
|
|
|
|
def get_backup_config(server_id):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_backup_config(server_id)
|
2021-09-09 00:01:10 +02:00
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
def set_backup_config(
|
2022-04-11 00:23:55 -05:00
|
|
|
self,
|
2022-03-23 02:50:12 +00:00
|
|
|
server_id: int,
|
|
|
|
backup_path: str = None,
|
|
|
|
max_backups: int = None,
|
|
|
|
excluded_dirs: list = None,
|
|
|
|
compress: bool = False,
|
2022-06-20 17:33:36 -04:00
|
|
|
shutdown: bool = False,
|
2023-01-21 13:13:02 -05:00
|
|
|
before: str = "",
|
|
|
|
after: str = "",
|
2022-03-23 02:50:12 +00:00
|
|
|
):
|
2022-04-11 00:23:55 -05:00
|
|
|
return self.management_helper.set_backup_config(
|
2023-01-20 17:35:30 -05:00
|
|
|
server_id,
|
|
|
|
backup_path,
|
|
|
|
max_backups,
|
|
|
|
excluded_dirs,
|
|
|
|
compress,
|
|
|
|
shutdown,
|
2023-01-21 13:13:02 -05:00
|
|
|
before,
|
|
|
|
after,
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2022-03-01 01:02:30 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_excluded_backup_dirs(server_id: int):
|
2022-04-14 03:10:25 +01:00
|
|
|
return HelpersManagement.get_excluded_backup_dirs(server_id)
|
2022-03-01 01:02:30 +00:00
|
|
|
|
2022-04-11 00:23:55 -05:00
|
|
|
def add_excluded_backup_dir(self, server_id: int, dir_to_add: str):
|
|
|
|
self.management_helper.add_excluded_backup_dir(server_id, dir_to_add)
|
2022-03-01 01:02:30 +00:00
|
|
|
|
2022-04-11 00:23:55 -05:00
|
|
|
def del_excluded_backup_dir(self, server_id: int, dir_to_del: str):
|
|
|
|
self.management_helper.del_excluded_backup_dir(server_id, dir_to_del)
|
2023-01-26 19:21:39 -05:00
|
|
|
|
|
|
|
# **********************************************************************************
|
|
|
|
# Crafty Methods
|
|
|
|
# **********************************************************************************
|
|
|
|
@staticmethod
|
|
|
|
def get_master_server_dir():
|
|
|
|
return HelpersManagement.get_master_server_dir()
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def set_master_server_dir(server_dir):
|
|
|
|
HelpersManagement.set_master_server_dir(server_dir)
|
2023-06-03 15:05:08 -04:00
|
|
|
|
|
|
|
# **********************************************************************************
|
|
|
|
# Webhooks Methods
|
|
|
|
# **********************************************************************************
|
|
|
|
@staticmethod
|
|
|
|
def create_webhook(data):
|
|
|
|
return HelpersWebhooks.create_webhook(data)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def modify_webhook(webhook_id, data):
|
|
|
|
HelpersWebhooks.modify_webhook(webhook_id, data)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_webhook_by_id(webhook_id):
|
|
|
|
return HelpersWebhooks.get_webhook_by_id(webhook_id)
|
|
|
|
|
|
|
|
@staticmethod
|
2023-06-03 18:11:59 -04:00
|
|
|
def get_webhooks_by_server(server_id, model=False):
|
|
|
|
return HelpersWebhooks.get_webhooks_by_server(server_id, model)
|
2023-06-03 15:05:08 -04:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def delete_webhook(webhook_id):
|
|
|
|
HelpersWebhooks.delete_webhook(webhook_id)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def delete_webhook_by_server(server_id):
|
|
|
|
HelpersWebhooks.delete_webhooks_by_server(server_id)
|