crafty-4/app/classes/models/servers.py

329 lines
11 KiB
Python
Raw Normal View History

2021-09-09 00:01:10 +02:00
import logging
import datetime
from peewee import (
ForeignKeyField,
CharField,
AutoField,
DateTimeField,
BooleanField,
IntegerField,
FloatField,
)
2021-09-09 00:01:10 +02:00
from app.classes.shared.main_models import DatabaseShortcuts
from app.classes.models.base_model import BaseModel
2021-09-09 00:01:10 +02:00
2022-03-08 04:40:44 +00:00
logger = logging.getLogger(__name__)
2021-09-09 00:01:10 +02:00
# **********************************************************************************
2021-09-09 00:01:10 +02:00
# Servers Class
# **********************************************************************************
class Servers(BaseModel):
2021-09-09 00:01:10 +02:00
server_id = AutoField()
created = DateTimeField(default=datetime.datetime.now)
server_uuid = CharField(default="", index=True)
server_name = CharField(default="Server", index=True)
path = CharField(default="")
backup_path = CharField(default="")
executable = CharField(default="")
log_path = CharField(default="")
execution_command = CharField(default="")
auto_start = BooleanField(default=0)
auto_start_delay = IntegerField(default=10)
crash_detection = BooleanField(default=0)
stop_command = CharField(default="stop")
executable_update_url = CharField(default="")
server_ip = CharField(default="127.0.0.1")
server_port = IntegerField(default=25565)
logs_delete_after = IntegerField(default=0)
type = CharField(default="minecraft-java")
2021-09-09 00:01:10 +02:00
class Meta:
table_name = "servers"
# **********************************************************************************
2021-09-09 00:01:10 +02:00
# Servers Stats Class
# **********************************************************************************
class ServerStats(BaseModel):
2021-09-09 00:01:10 +02:00
stats_id = AutoField()
created = DateTimeField(default=datetime.datetime.now)
server_id = ForeignKeyField(Servers, backref="server", index=True)
2021-09-09 00:01:10 +02:00
started = CharField(default="")
running = BooleanField(default=False)
cpu = FloatField(default=0)
mem = FloatField(default=0)
mem_percent = FloatField(default=0)
world_name = CharField(default="")
world_size = CharField(default="")
server_port = IntegerField(default=25565)
int_ping_results = CharField(default="")
online = IntegerField(default=0)
max = IntegerField(default=0)
players = CharField(default="")
desc = CharField(default="Unable to Connect")
version = CharField(default="")
updating = BooleanField(default=False)
2021-09-21 21:13:17 +02:00
waiting_start = BooleanField(default=False)
first_run = BooleanField(default=True)
2022-01-27 20:43:23 -05:00
crashed = BooleanField(default=False)
2022-03-04 00:36:36 +00:00
downloading = BooleanField(default=False)
2021-09-09 00:01:10 +02:00
class Meta:
table_name = "server_stats"
# **********************************************************************************
2021-09-09 00:01:10 +02:00
# Servers Class
# **********************************************************************************
class HelperServers:
def __init__(self, database):
self.database = database
# **********************************************************************************
2021-09-09 00:01:10 +02:00
# Generic Servers Methods
# **********************************************************************************
2021-09-09 00:01:10 +02:00
@staticmethod
def create_server(
name: str,
server_uuid: str,
server_dir: str,
backup_path: str,
server_command: str,
server_file: str,
server_log_file: str,
server_stop: str,
2022-02-10 18:20:36 -05:00
server_type: str,
server_port=25565,
):
return Servers.insert(
{
Servers.server_name: name,
Servers.server_uuid: server_uuid,
Servers.path: server_dir,
Servers.executable: server_file,
Servers.execution_command: server_command,
Servers.auto_start: False,
Servers.auto_start_delay: 10,
Servers.crash_detection: False,
Servers.log_path: server_log_file,
Servers.server_port: server_port,
Servers.stop_command: server_stop,
Servers.backup_path: backup_path,
Servers.type: server_type,
}
).execute()
@staticmethod
def get_server_obj(server_id):
return Servers.get_by_id(server_id)
2022-02-10 18:20:36 -05:00
@staticmethod
def get_server_type_by_id(server_id):
server_type = Servers.select().where(Servers.server_id == server_id).get()
return server_type.type
@staticmethod
def update_server(server_obj):
return server_obj.save()
def remove_server(self, server_id):
with self.database.atomic():
Servers.delete().where(Servers.server_id == server_id).execute()
2021-09-09 00:01:10 +02:00
@staticmethod
def get_server_data_by_id(server_id):
query = Servers.select().where(Servers.server_id == server_id).limit(1)
try:
return DatabaseShortcuts.return_rows(query)[0]
2021-09-09 00:01:10 +02:00
except IndexError:
return {}
# **********************************************************************************
2021-09-09 00:01:10 +02:00
# Servers Methods
# **********************************************************************************
2021-09-09 00:01:10 +02:00
@staticmethod
def get_all_defined_servers():
query = Servers.select()
return DatabaseShortcuts.return_rows(query)
2021-09-09 00:01:10 +02:00
@staticmethod
def get_all_servers_stats():
servers = HelperServers.get_all_defined_servers()
2021-09-09 00:01:10 +02:00
server_data = []
try:
for s in servers:
latest = (
ServerStats.select()
.where(ServerStats.server_id == s.get("server_id"))
.order_by(ServerStats.created.desc())
.limit(1)
)
server_data.append(
{
"server_data": s,
"stats": DatabaseShortcuts.return_rows(latest)[0],
"user_command_permission": True,
}
)
except IndexError as ex:
logger.error(
f"Stats collection failed with error: {ex}. Was a server just created?"
)
2021-09-09 00:01:10 +02:00
return server_data
@staticmethod
def get_server_friendly_name(server_id):
server_data = HelperServers.get_server_data_by_id(server_id)
friendly_name = (
f"{server_data.get('server_name', None)} "
f"with ID: {server_data.get('server_id', 0)}"
)
2021-09-09 00:01:10 +02:00
return friendly_name
# **********************************************************************************
2021-09-09 00:01:10 +02:00
# Servers_Stats Methods
# **********************************************************************************
2021-09-09 00:01:10 +02:00
@staticmethod
def get_latest_server_stats(server_id):
return (
ServerStats.select()
.where(ServerStats.server_id == server_id)
.order_by(ServerStats.created.desc())
.limit(1)
)
2021-09-09 00:01:10 +02:00
@staticmethod
def get_server_stats_by_id(server_id):
stats = (
ServerStats.select()
.where(ServerStats.server_id == server_id)
.order_by(ServerStats.created.desc())
.limit(1)
)
return DatabaseShortcuts.return_rows(stats)[0]
2021-09-09 00:01:10 +02:00
@staticmethod
def server_id_exists(server_id):
if not HelperServers.get_server_data_by_id(server_id):
2021-09-09 00:01:10 +02:00
return False
return True
2022-01-27 20:43:23 -05:00
@staticmethod
def sever_crashed(server_id):
ServerStats.update(crashed=True).where(
ServerStats.server_id == server_id
).execute()
2022-01-27 20:43:23 -05:00
2022-03-04 00:36:36 +00:00
@staticmethod
def set_download(server_id):
ServerStats.update(downloading=True).where(
ServerStats.server_id == server_id
).execute()
2022-03-04 00:36:36 +00:00
@staticmethod
def finish_download(server_id):
ServerStats.update(downloading=False).where(
ServerStats.server_id == server_id
).execute()
2022-03-04 00:36:36 +00:00
@staticmethod
def get_download_status(server_id):
download_status = (
ServerStats.select().where(ServerStats.server_id == server_id).get()
)
2022-03-04 00:36:36 +00:00
return download_status.downloading
2022-01-27 20:43:23 -05:00
@staticmethod
def server_crash_reset(server_id):
ServerStats.update(crashed=False).where(
ServerStats.server_id == server_id
).execute()
2022-01-27 20:43:23 -05:00
@staticmethod
def is_crashed(server_id):
svr = ServerStats.select().where(ServerStats.server_id == server_id).get()
if svr.crashed is True:
2022-01-27 20:43:23 -05:00
return True
else:
return False
2021-09-09 00:01:10 +02:00
@staticmethod
def set_update(server_id, value):
try:
# Checks if server even exists
ServerStats.select().where(ServerStats.server_id == server_id)
2021-09-09 00:01:10 +02:00
except Exception as ex:
logger.error(f"Database entry not found! {ex}")
ServerStats.update(updating=value).where(
ServerStats.server_id == server_id
).execute()
2021-09-09 00:01:10 +02:00
@staticmethod
def get_update_status(server_id):
update_status = (
ServerStats.select().where(ServerStats.server_id == server_id).get()
)
2022-01-27 20:43:23 -05:00
return update_status.updating
@staticmethod
def set_first_run(server_id):
# Sets first run to false
try:
# Checks if server even exists
ServerStats.select().where(ServerStats.server_id == server_id)
except Exception as ex:
logger.error(f"Database entry not found! {ex}")
return
ServerStats.update(first_run=False).where(
ServerStats.server_id == server_id
).execute()
@staticmethod
def get_first_run(server_id):
first_run = ServerStats.select().where(ServerStats.server_id == server_id).get()
return first_run.first_run
2021-09-09 00:01:10 +02:00
@staticmethod
def get_ttl_without_player(server_id):
last_stat = (
ServerStats.select()
.where(ServerStats.server_id == server_id)
.order_by(ServerStats.created.desc())
.first()
)
last_stat_with_player = (
ServerStats.select()
.where(ServerStats.server_id == server_id)
.where(ServerStats.online > 0)
.order_by(ServerStats.created.desc())
.first()
)
2021-09-09 00:01:10 +02:00
return last_stat.created - last_stat_with_player.created
@staticmethod
def can_stop_no_players(server_id, time_limit):
can = False
ttl_no_players = HelperServers.get_ttl_without_player(server_id)
2021-09-09 00:01:10 +02:00
if (time_limit == -1) or (ttl_no_players > time_limit):
can = True
return can
2021-09-21 21:13:17 +02:00
@staticmethod
def set_waiting_start(server_id, value):
try:
# Checks if server even exists
ServerStats.select().where(ServerStats.server_id == server_id)
2021-09-21 21:13:17 +02:00
except Exception as ex:
logger.error(f"Database entry not found! {ex}")
ServerStats.update(waiting_start=value).where(
ServerStats.server_id == server_id
).execute()
2021-09-21 21:13:17 +02:00
@staticmethod
def get_waiting_start(server_id):
waiting_start = (
ServerStats.select().where(ServerStats.server_id == server_id).get()
)
2021-09-21 21:13:17 +02:00
return waiting_start.waiting_start