mkcontrol-app/app/__init__.py
2026-02-16 21:53:09 +01:00

65 lines
2.0 KiB
Python

# app/__init__.py (App-Factory)
import logging
import threading
import time
import os
import pygame
from flask import Flask
from .utils.logging import setup_logging, cleanup_old_log_dirs
from .routes.main import main_bp
from .routes.admin import admin_bp
from .routes.api import api_bp
from .bluetooth.manager import init_bluetooth
logger = logging.getLogger(__name__) # ← Logger für diese Datei
def create_app():
app = Flask(__name__,
template_folder='../templates', # ← Root/templates statt app/templates
static_folder='../static') # ← Root/static
# Config laden
app.config.from_object('config.Config')
# Logging zuerst (vor allem anderen)
setup_logging(app)
# Bluetooth initialisieren (Monitor-Thread startet automatisch)
init_bluetooth()
# pygame initialisieren (einmalig)
from config import Config
pygame.mixer.pre_init(frequency=Config.AUDIO_FREQ,
size=Config.AUDIO_SIZE,
channels=Config.AUDIO_CHANNELS,
buffer=Config.AUDIO_BUFFER)
pygame.mixer.init()
pygame.mixer.set_num_channels(Config.AUDIO_NUM_CHANNELS) # genug parallele Kanäle für BG + Effekte
pygame.mixer.music.set_volume(0.8) # Standard-Lautstärke (für Legacy-Fälle)
app.logger.info("pygame initialisiert")
# Blueprints registrieren
from .routes.main import main_bp
from .routes.admin import admin_bp
from .routes.api import api_bp
# Blueprints registrieren
app.register_blueprint(main_bp)
app.register_blueprint(admin_bp, url_prefix='/admin')
app.register_blueprint(api_bp, url_prefix='/api')
# Täglicher Cleanup-Thread starten (einmalig)
def daily_cleanup():
while True:
cleanup_old_log_dirs(90)
time.sleep(86400) # 24 Stunden
cleanup_thread = threading.Thread(target=daily_cleanup, daemon=True)
cleanup_thread.start()
logger.info("Täglicher Log-Cleanup-Thread gestartet (24h Intervall)")
return app