mirror of
https://github.com/Derpy-Leggies/OnlyLegs.git
synced 2025-01-04 05:46:14 +00:00
126 lines
3.7 KiB
Python
126 lines
3.7 KiB
Python
"""
|
|
OnlyLegs - Setup
|
|
Runs when the app detects that there is no user directory
|
|
"""
|
|
import os
|
|
import sys
|
|
import platformdirs
|
|
import logging
|
|
import yaml
|
|
|
|
|
|
USER_DIR = platformdirs.user_config_dir('onlylegs')
|
|
|
|
|
|
class SetupApp:
|
|
"""
|
|
Setup the application on first run
|
|
"""
|
|
def __init__(self):
|
|
"""
|
|
Main setup function
|
|
"""
|
|
print("Running setup...")
|
|
|
|
self.requires_restart = False
|
|
|
|
if not os.path.exists(USER_DIR):
|
|
self.make_dir()
|
|
if not os.path.exists(os.path.join(USER_DIR, '.env')):
|
|
self.make_env()
|
|
if not os.path.exists(os.path.join(USER_DIR, 'conf.yml')):
|
|
self.make_yaml()
|
|
|
|
self.logging_config()
|
|
|
|
if self.requires_restart:
|
|
print("WARNING: You need to restart and edit the config files before running the app again!")
|
|
print("You can find the config files at:", USER_DIR)
|
|
sys.exit()
|
|
|
|
@staticmethod
|
|
def make_dir():
|
|
"""
|
|
Create the user directory
|
|
"""
|
|
try:
|
|
os.makedirs(USER_DIR)
|
|
os.makedirs(os.path.join(USER_DIR, 'instance'))
|
|
|
|
print("Created user directory at:", USER_DIR)
|
|
except Exception as err:
|
|
print("Error creating user directory:", err)
|
|
sys.exit(1)
|
|
|
|
@staticmethod
|
|
def make_env():
|
|
"""
|
|
Create the .env file with default values
|
|
"""
|
|
env_conf = {
|
|
'FLASK_SECRET': 'dev',
|
|
}
|
|
try:
|
|
with open(os.path.join(USER_DIR, '.env'), encoding='utf-8', mode='w+') as file:
|
|
for key, value in env_conf.items():
|
|
file.write(f"{key}={value}\n")
|
|
print("Created environment variables")
|
|
except Exception as err:
|
|
print("Error creating environment variables:", err)
|
|
sys.exit(1)
|
|
|
|
print("Generated default .env file, please edit!")
|
|
|
|
@staticmethod
|
|
def make_yaml():
|
|
"""
|
|
Create the YAML config file with default values
|
|
"""
|
|
yaml_conf = {
|
|
'admin': {
|
|
'name': 'Real Person',
|
|
'username': 'User',
|
|
'email': 'real-email@some.place'
|
|
},
|
|
'upload': {
|
|
'allowed-extensions': {
|
|
'jpg': 'jpeg',
|
|
'jpeg': 'jpeg',
|
|
'png': 'png',
|
|
'webp': 'webp'
|
|
},
|
|
'max-size': 69,
|
|
'rename': 'GWA_\{\{username\}\}_\{\{time\}\}'
|
|
},
|
|
'website': {
|
|
'name': 'OnlyLegs',
|
|
'motto': 'Gwa Gwa',
|
|
'language': 'english'
|
|
}
|
|
}
|
|
try:
|
|
with open(os.path.join(USER_DIR, 'conf.yml'), encoding='utf-8', mode='w+') as file:
|
|
yaml.dump(yaml_conf, file, default_flow_style=False)
|
|
print("Created default gallery config")
|
|
except Exception as err:
|
|
print("Error creating default gallery config:", err)
|
|
sys.exit(1)
|
|
|
|
print("Generated default YAML config, please edit!")
|
|
|
|
@staticmethod
|
|
def logging_config():
|
|
logs_path = os.path.join(platformdirs.user_config_dir('onlylegs'), 'logs')
|
|
|
|
if not os.path.isdir(logs_path):
|
|
os.mkdir(logs_path)
|
|
print("Created logs directory at:", logs_path)
|
|
|
|
logging.getLogger('werkzeug').disabled = True
|
|
logging.basicConfig(
|
|
filename=os.path.join(logs_path, 'only.log'),
|
|
level=logging.INFO,
|
|
datefmt='%Y-%m-%d %H:%M:%S',
|
|
format='%(asctime)s %(levelname)s %(name)s %(threadName)s : %(message)s',
|
|
encoding='utf-8')
|