50 MrtveTorrenty: add criterion B — stuck near 100% for 7+ days

This commit is contained in:
2026-03-01 07:55:12 +01:00
parent bf81c037a9
commit b5b3da1105

View File

@@ -6,17 +6,19 @@ from datetime import datetime, timedelta
# CONFIG # CONFIG
# ============================================================ # ============================================================
DRY_RUN = True # ← změň na False až si ověříš výstup DRY_RUN = False # ← změň na False až si ověříš výstup
DEAD_AFTER_HOURS = 72 # torrent musí být v qB alespoň tolik hodin DEAD_AFTER_HOURS = 72 # torrent musí být v qB alespoň tolik hodin
DEAD_PROGRESS_THRESHOLD = 95.0 # pokud je progress < tato % po uplynutí doby → dead DEAD_PROGRESS_THRESHOLD = 95.0 # pokud je progress < tato % po uplynutí doby → dead
STUCK_AFTER_HOURS = 168 # 7 dní — pro torrenty téměř hotové (>= 95%) ale zaseknuté
QBT_URL = "https://vladob.zen.usbx.me/qbittorrent" QBT_URL = "https://vladob.zen.usbx.me/qbittorrent"
QBT_USER = "vladob" QBT_USER = "vladob"
QBT_PASS = "jCni3U6d#y4bfcm" QBT_PASS = "jCni3U6d#y4bfcm"
DB_CONFIG = { DB_CONFIG = {
"host": "192.168.1.50", "host": "192.168.1.76",
"port": 3306, "port": 3306,
"user": "root", "user": "root",
"password": "Vlado9674+", "password": "Vlado9674+",
@@ -53,7 +55,8 @@ def main():
print("=" * 60) print("=" * 60)
print("MRTVÉ TORRENTY — UltraCC Seedbox cleanup") print("MRTVÉ TORRENTY — UltraCC Seedbox cleanup")
print(f"DRY_RUN = {DRY_RUN}") print(f"DRY_RUN = {DRY_RUN}")
print(f"Kritéria : v qB déle než {DEAD_AFTER_HOURS}h A progress < {DEAD_PROGRESS_THRESHOLD}%") print(f"Kritérium A: progress < {DEAD_PROGRESS_THRESHOLD}% A v qB déle než {DEAD_AFTER_HOURS}h")
print(f"Kritérium B: progress >= {DEAD_PROGRESS_THRESHOLD}% ale < 100% A v qB déle než {STUCK_AFTER_HOURS}h (zaseknutý)")
print("=" * 60) print("=" * 60)
qbt = connect_qbt() qbt = connect_qbt()
@@ -63,7 +66,8 @@ def main():
torrents = qbt.torrents_info() torrents = qbt.torrents_info()
now = datetime.now() now = datetime.now()
deadline = now - timedelta(hours=DEAD_AFTER_HOURS) deadline_a = now - timedelta(hours=DEAD_AFTER_HOURS)
deadline_b = now - timedelta(hours=STUCK_AFTER_HOURS)
dead_count = 0 dead_count = 0
skip_count = 0 skip_count = 0
@@ -83,22 +87,23 @@ def main():
added_dt = datetime.fromtimestamp(added_on) added_dt = datetime.fromtimestamp(added_on)
progress_pct = float(t.progress) * 100.0 progress_pct = float(t.progress) * 100.0
age_hours = (now - added_dt).total_seconds() / 3600
# Torrent ještě není dost starý # ── Kritérium A: nízký progress po 72h ────────────────
if added_dt > deadline: is_dead_a = (added_dt <= deadline_a) and (progress_pct < DEAD_PROGRESS_THRESHOLD)
skip_count += 1
continue
# Progress je OK (téměř hotov) → přeskočit # ── Kritérium B: zaseknutý blízko 100% po 7 dnech ─────
if progress_pct >= DEAD_PROGRESS_THRESHOLD: is_dead_b = (added_dt <= deadline_b) and (progress_pct >= DEAD_PROGRESS_THRESHOLD) and (progress_pct < 100.0)
if not is_dead_a and not is_dead_b:
skip_count += 1 skip_count += 1
continue continue
# ── Torrent splňuje kritéria "mrtvý" ────────────────── # ── Torrent splňuje kritéria "mrtvý" ──────────────────
thash = t.hash.lower() thash = t.hash.lower()
age_hours = (now - added_dt).total_seconds() / 3600 reason = "nízký progress po 72h" if is_dead_a else "zaseknutý blízko 100% po 7 dnech"
print(f"\n💀 MRTVÝ: {t.name}") print(f"\n💀 MRTVÝ ({reason}): {t.name}")
print(f" Přidán : {added_dt} ({age_hours:.1f}h zpět)") print(f" Přidán : {added_dt} ({age_hours:.1f}h zpět)")
print(f" Progress : {progress_pct:.1f}%") print(f" Progress : {progress_pct:.1f}%")
print(f" Stav : {t.state}") print(f" Stav : {t.state}")