fix: asyncio Fallback-Loop fuer daily_forecast (kein JobQueue)

This commit is contained in:
Homelab Cursor 2026-03-21 13:20:45 +01:00
parent c4553b46d7
commit 4202926830
2 changed files with 17 additions and 0 deletions

View file

@ -973,12 +973,29 @@ def main():
except Exception:
log.exception("Fehler im Filmtipp-Loop")
async def _forecast_loop(application):
"""Fallback: asyncio-basierter täglicher Forecast (08:00 Uhr)."""
while True:
now = datetime.now()
target = now.replace(hour=8, minute=0, second=0, microsecond=0)
if now >= target:
from datetime import timedelta
target += timedelta(days=1)
wait_secs = (target - now).total_seconds()
log.info("Forecast-Loop: nächster Run in %.0f Sek (%s)", wait_secs, target)
await asyncio.sleep(wait_secs)
try:
await _send_daily_forecast(application)
except Exception:
log.exception("Fehler im Forecast-Loop")
async def post_init(application):
await application.bot.set_my_commands(BOT_COMMANDS)
log.info("Kommandomenü registriert")
asyncio.create_task(_watchdog_loop())
if application.job_queue is None:
asyncio.create_task(_filmtipp_loop(application))
asyncio.create_task(_forecast_loop(application))
_sd_notify("READY=1")
log.info("Systemd Watchdog aktiv (50s Intervall)")