df
Some checks failed
smoke-mm / Install & smoke test mm --help (push) Has been cancelled
Some checks failed
smoke-mm / Install & smoke test mm --help (push) Has been cancelled
This commit is contained in:
@@ -17,6 +17,7 @@ from typing import Any, Dict, Optional, Sequence
|
||||
from SYS.logger import log
|
||||
from . import _shared as sh
|
||||
|
||||
|
||||
class Download_Torrent(sh.Cmdlet):
|
||||
"""Class-based download-torrent cmdlet with self-registration."""
|
||||
|
||||
@@ -27,10 +28,29 @@ class Download_Torrent(sh.Cmdlet):
|
||||
usage="download-torrent <magnet|.torrent> [options]",
|
||||
alias=["torrent", "magnet"],
|
||||
arg=[
|
||||
sh.CmdletArg(name="magnet", type="string", required=False, description="Magnet link or .torrent file/URL", variadic=True),
|
||||
sh.CmdletArg(name="output", type="string", description="Output directory for downloaded files"),
|
||||
sh.CmdletArg(name="wait", type="float", description="Wait time (seconds) for magnet processing timeout"),
|
||||
sh.CmdletArg(name="background", type="flag", alias="bg", description="Start download in background"),
|
||||
sh.CmdletArg(
|
||||
name="magnet",
|
||||
type="string",
|
||||
required=False,
|
||||
description="Magnet link or .torrent file/URL",
|
||||
variadic=True,
|
||||
),
|
||||
sh.CmdletArg(
|
||||
name="output",
|
||||
type="string",
|
||||
description="Output directory for downloaded files",
|
||||
),
|
||||
sh.CmdletArg(
|
||||
name="wait",
|
||||
type="float",
|
||||
description="Wait time (seconds) for magnet processing timeout",
|
||||
),
|
||||
sh.CmdletArg(
|
||||
name="background",
|
||||
type="flag",
|
||||
alias="bg",
|
||||
description="Start download in background",
|
||||
),
|
||||
],
|
||||
detail=["Download torrents/magnets via AllDebrid API."],
|
||||
exec=self.run,
|
||||
@@ -51,7 +71,10 @@ class Download_Torrent(sh.Cmdlet):
|
||||
except Exception:
|
||||
api_key = None
|
||||
if not api_key:
|
||||
log("AllDebrid API key not configured (check config.conf [provider=alldebrid] api_key=...)", file=sys.stderr)
|
||||
log(
|
||||
"AllDebrid API key not configured (check config.conf [provider=alldebrid] api_key=...)",
|
||||
file=sys.stderr,
|
||||
)
|
||||
return 1
|
||||
for magnet_url in magnet_args:
|
||||
if background_mode:
|
||||
@@ -64,7 +87,9 @@ class Download_Torrent(sh.Cmdlet):
|
||||
magnet_id = self._submit_magnet(worker_id, magnet_url, api_key)
|
||||
if magnet_id <= 0:
|
||||
continue
|
||||
self._start_background_magnet_worker(worker_id, magnet_id, output_dir, api_key, wait_timeout)
|
||||
self._start_background_magnet_worker(
|
||||
worker_id, magnet_id, output_dir, api_key, wait_timeout
|
||||
)
|
||||
log(f"⧗ Torrent processing started (ID: {magnet_id})")
|
||||
return 0
|
||||
|
||||
@@ -80,7 +105,7 @@ class Download_Torrent(sh.Cmdlet):
|
||||
client = AllDebridClient(api_key)
|
||||
log(f"[Worker {worker_id}] Submitting magnet to AllDebrid...")
|
||||
magnet_info = client.magnet_add(magnet_url)
|
||||
magnet_id = int(magnet_info.get('id', 0))
|
||||
magnet_id = int(magnet_info.get("id", 0))
|
||||
if magnet_id <= 0:
|
||||
log(f"[Worker {worker_id}] Magnet add failed", file=sys.stderr)
|
||||
return 0
|
||||
@@ -90,7 +115,9 @@ class Download_Torrent(sh.Cmdlet):
|
||||
log(f"[Worker {worker_id}] Magnet submit failed: {e}", file=sys.stderr)
|
||||
return 0
|
||||
|
||||
def _start_background_magnet_worker(self, worker_id: str, magnet_id: int, output_dir: Path, api_key: str, wait_timeout: int) -> None:
|
||||
def _start_background_magnet_worker(
|
||||
self, worker_id: str, magnet_id: int, output_dir: Path, api_key: str, wait_timeout: int
|
||||
) -> None:
|
||||
thread = threading.Thread(
|
||||
target=self._download_magnet_worker,
|
||||
args=(worker_id, magnet_id, output_dir, api_key, wait_timeout),
|
||||
@@ -119,7 +146,7 @@ class Download_Torrent(sh.Cmdlet):
|
||||
elapsed = 0
|
||||
while elapsed < wait_timeout:
|
||||
status = client.magnet_status(magnet_id)
|
||||
if status.get('ready'):
|
||||
if status.get("ready"):
|
||||
break
|
||||
time.sleep(5)
|
||||
elapsed += 5
|
||||
@@ -129,13 +156,13 @@ class Download_Torrent(sh.Cmdlet):
|
||||
|
||||
files_result = client.magnet_links([magnet_id])
|
||||
magnet_files = files_result.get(str(magnet_id), {})
|
||||
files_array = magnet_files.get('files', [])
|
||||
files_array = magnet_files.get("files", [])
|
||||
if not files_array:
|
||||
log(f"[Worker {worker_id}] No files found", file=sys.stderr)
|
||||
return
|
||||
for file_info in files_array:
|
||||
file_url = file_info.get('link')
|
||||
file_name = file_info.get('name')
|
||||
file_url = file_info.get("link")
|
||||
file_name = file_info.get("name")
|
||||
if file_url and file_name:
|
||||
Download_Torrent._download_file(file_url, output_dir / file_name)
|
||||
log(f"[Worker {worker_id}] ✓ Downloaded {file_name}")
|
||||
@@ -154,20 +181,22 @@ class Download_Torrent(sh.Cmdlet):
|
||||
) -> None:
|
||||
try:
|
||||
from API.alldebrid import AllDebridClient
|
||||
|
||||
client = AllDebridClient(api_key)
|
||||
log(f"[Worker {worker_id}] Submitting magnet to AllDebrid...")
|
||||
magnet_info = client.magnet_add(magnet_url)
|
||||
magnet_id = int(magnet_info.get('id', 0))
|
||||
magnet_id = int(magnet_info.get("id", 0))
|
||||
if magnet_id <= 0:
|
||||
log(f"[Worker {worker_id}] Magnet add failed", file=sys.stderr)
|
||||
return
|
||||
log(f"[Worker {worker_id}] ✓ Magnet added (ID: {magnet_id})")
|
||||
# Poll for ready status (simplified)
|
||||
import time
|
||||
|
||||
elapsed = 0
|
||||
while elapsed < wait_timeout:
|
||||
status = client.magnet_status(magnet_id)
|
||||
if status.get('ready'):
|
||||
if status.get("ready"):
|
||||
break
|
||||
time.sleep(5)
|
||||
elapsed += 5
|
||||
@@ -176,13 +205,13 @@ class Download_Torrent(sh.Cmdlet):
|
||||
return
|
||||
files_result = client.magnet_links([magnet_id])
|
||||
magnet_files = files_result.get(str(magnet_id), {})
|
||||
files_array = magnet_files.get('files', [])
|
||||
files_array = magnet_files.get("files", [])
|
||||
if not files_array:
|
||||
log(f"[Worker {worker_id}] No files found", file=sys.stderr)
|
||||
return
|
||||
for file_info in files_array:
|
||||
file_url = file_info.get('link')
|
||||
file_name = file_info.get('name')
|
||||
file_url = file_info.get("link")
|
||||
file_name = file_info.get("name")
|
||||
if file_url:
|
||||
Download_Torrent._download_file(file_url, output_dir / file_name)
|
||||
log(f"[Worker {worker_id}] ✓ Downloaded {file_name}")
|
||||
@@ -193,8 +222,9 @@ class Download_Torrent(sh.Cmdlet):
|
||||
def _download_file(url: str, dest: Path) -> None:
|
||||
try:
|
||||
import requests
|
||||
|
||||
resp = requests.get(url, stream=True)
|
||||
with open(dest, 'wb') as f:
|
||||
with open(dest, "wb") as f:
|
||||
for chunk in resp.iter_content(chunk_size=8192):
|
||||
if chunk:
|
||||
f.write(chunk)
|
||||
@@ -211,4 +241,5 @@ class Download_Torrent(sh.Cmdlet):
|
||||
)
|
||||
thread.start()
|
||||
|
||||
|
||||
CMDLET = Download_Torrent()
|
||||
|
||||
Reference in New Issue
Block a user