2021-09-08 22:01:10 +00:00
|
|
|
import logging
|
2022-04-11 05:23:55 +00:00
|
|
|
from playhouse.shortcuts import model_to_dict
|
2021-09-08 22:01:10 +00:00
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
from app.classes.shared.helpers import Helpers # pylint: disable=unused-import
|
2022-04-17 17:27:00 +00:00
|
|
|
from app.classes.shared.console import Console
|
2021-09-08 22:01:10 +00:00
|
|
|
|
2022-03-08 04:40:44 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
2021-09-08 22:01:10 +00:00
|
|
|
|
2022-04-11 10:08:36 +00:00
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
class DatabaseBuilder:
|
2023-01-29 21:54:02 +00:00
|
|
|
def __init__(self, database, helper, users_helper, management_helper):
|
2022-04-11 05:23:55 +00:00
|
|
|
self.database = database
|
|
|
|
self.helper = helper
|
2023-01-29 21:54:02 +00:00
|
|
|
self.management_helper = management_helper
|
2022-04-11 05:23:55 +00:00
|
|
|
self.users_helper = users_helper
|
|
|
|
|
2023-11-13 19:14:13 +00:00
|
|
|
def default_settings(self, password="crafty"):
|
2021-09-08 22:01:10 +00:00
|
|
|
logger.info("Fresh Install Detected - Creating Default Settings")
|
2022-04-17 17:27:00 +00:00
|
|
|
Console.info("Fresh Install Detected - Creating Default Settings")
|
2022-04-11 05:23:55 +00:00
|
|
|
default_data = self.helper.find_default_password()
|
2024-02-20 02:14:15 +00:00
|
|
|
if "password" not in default_data:
|
2023-11-13 22:23:02 +00:00
|
|
|
Console.help(
|
|
|
|
"No default password found. Using password created "
|
|
|
|
"by Crafty. Find it in app/config/default-creds.txt"
|
|
|
|
)
|
2022-03-23 02:50:12 +00:00
|
|
|
username = default_data.get("username", "admin")
|
2024-03-04 00:18:18 +00:00
|
|
|
if self.helper.minimum_password_length > len(
|
|
|
|
default_data.get("password", password)
|
|
|
|
):
|
2024-02-20 02:14:15 +00:00
|
|
|
Console.critical(
|
|
|
|
"Default password too short"
|
|
|
|
" using Crafty's created default."
|
|
|
|
" Find it in app/config/default-creds.txt"
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
password = default_data.get("password", password)
|
2022-01-26 01:45:30 +00:00
|
|
|
|
2022-04-11 05:23:55 +00:00
|
|
|
self.users_helper.add_user(
|
2022-03-23 02:50:12 +00:00
|
|
|
username=username,
|
|
|
|
password=password,
|
|
|
|
email="default@example.com",
|
|
|
|
superuser=True,
|
2022-08-27 15:17:31 +00:00
|
|
|
manager=None,
|
2022-03-23 02:50:12 +00:00
|
|
|
)
|
2021-09-08 22:01:10 +00:00
|
|
|
|
2023-01-29 21:54:02 +00:00
|
|
|
self.management_helper.create_crafty_row()
|
|
|
|
|
2022-04-11 05:23:55 +00:00
|
|
|
def is_fresh_install(self):
|
2021-09-08 22:01:10 +00:00
|
|
|
try:
|
2022-08-07 15:30:00 +00:00
|
|
|
num_user = self.users_helper.get_user_total()
|
|
|
|
return num_user <= 0
|
2021-09-08 22:01:10 +00:00
|
|
|
except:
|
|
|
|
return True
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
class DatabaseShortcuts:
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
# Generic Databse Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
@staticmethod
|
|
|
|
def return_rows(query):
|
|
|
|
rows = []
|
|
|
|
|
|
|
|
try:
|
|
|
|
if query.count() > 0:
|
|
|
|
for s in query:
|
|
|
|
rows.append(model_to_dict(s))
|
|
|
|
except Exception as e:
|
2022-01-26 01:45:30 +00:00
|
|
|
logger.warning(f"Database Error: {e}")
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
return rows
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def return_db_rows(model):
|
|
|
|
data = [model_to_dict(row) for row in model]
|
|
|
|
return data
|
2022-05-26 21:19:59 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_data_obj(obj):
|
|
|
|
return model_to_dict(obj)
|