diff --git a/comet/api/stream.py b/comet/api/stream.py index be2a848..53bcd92 100644 --- a/comet/api/stream.py +++ b/comet/api/stream.py @@ -147,7 +147,7 @@ async def stream( config["debridApiKey"] = settings.PROXY_DEBRID_STREAM_DEBRID_DEFAULT_APIKEY if config["debridApiKey"] == "": - services = ["realdebrid", "alldebrid", "premiumize", "torbox", "debridlink", "easydebrid"] + services = ["realdebrid", "alldebrid", "premiumize", "torbox", "debridlink"] debrid_emoji = "⬇️" else: services = [config["debridService"]] @@ -462,10 +462,6 @@ async def stream( torrent_size = torrents_by_hash[hash]["Size"] sorted_ranked_files[hash]["data"]["size"] = ( files[hash]["size"] - if config["debridService"] != "easydebrid" - else torrent_size - if torrent_size - else 0 ) sorted_ranked_files[hash]["data"]["torrent_size"] = ( torrent_size if torrent_size else files[hash]["size"] diff --git a/comet/debrid/easydebrid.py b/comet/debrid/easydebrid.py deleted file mode 100644 index 4ebf2dc..0000000 --- a/comet/debrid/easydebrid.py +++ /dev/null @@ -1,184 +0,0 @@ -import aiohttp -import asyncio - -from RTN import parse - -from comet.utils.general import is_video -from comet.utils.logger import logger - - -class EasyDebrid: - def __init__(self, session: aiohttp.ClientSession, debrid_api_key: str, ip: str): - self.session = session - self.ip = ip - self.proxy = None - - self.api_url = "https://easydebrid.com/api/v1" - self.headers = {"Authorization": f"Bearer {debrid_api_key}"} - - if ip: - self.headers["X-Forwarded-For"] = ip - - async def check_premium(self): - try: - response = await self.session.get( - f"{self.api_url}/user/details", headers=self.headers - ) - data = await response.json() - return bool(data["paid_until"]) - except Exception as e: - logger.warning(f"Failed to check EasyDebrid premium status: {e}") - - return False - - async def get_instant(self, chunk): - try: - response = await self.session.post( - f"{self.api_url}/link/lookup", - json={"urls": chunk}, - headers=self.headers, - ) - data = await response.json() - - if not data or "cached" not in data: - return None - - return { - "status": "success", - "response": data["cached"], - "filename": data.get("filenames", []), - "filesize": [None] * len(chunk), - "hashes": chunk, - } - except Exception as e: - logger.warning( - f"Exception while checking hash instant availability on EasyDebrid: {e}" - ) - - async def get_files(self, torrent_hashes, type, season, episode, kitsu): - chunk_size = 100 - chunks = [ - torrent_hashes[i : i + chunk_size] - for i in range(0, len(torrent_hashes), chunk_size) - ] - - tasks = [] - for chunk in chunks: - tasks.append(self.get_instant(chunk)) - - responses = await asyncio.gather(*tasks) - - files = {} - - if type == "series": - for result in responses: - if result["status"] != "success": - continue - - responses = result["response"] - filenames = result["filename"] - hashes = result["hashes"] - - for index, (is_cached, hash) in enumerate(zip(responses, hashes)): - if not is_cached: - continue - - try: - hash_files = filenames[index] - except: - hash_files = filenames[str(index)] - - for filename in hash_files: - if not is_video(filename): - continue - - if "sample" in filename.lower(): - continue - - filename_parsed = parse(filename) - if not filename_parsed: - continue - - if episode not in filename_parsed.episodes: - continue - - if kitsu: - if filename_parsed.seasons: - continue - elif season not in filename_parsed.seasons: - continue - - files[hash] = { - "index": f"{season}|{episode}", - "title": filename, - "size": 0, # Size not available in lookup response - } - break # Found matching video file - else: - for result in responses: - if result["status"] != "success": - continue - - responses = result["response"] - filenames = result["filename"] - hashes = result["hashes"] - - for index, (is_cached, hash) in enumerate(zip(responses, hashes)): - if not is_cached: - continue - - try: - hash_files = filenames[index] - except: - hash_files = filenames[str(index)] - - video_files = [f for f in hash_files if is_video(f)] - if not video_files: - continue - - # Use first valid video file found - files[hash] = { - "index": 0, - "title": video_files[0], - "size": 0, # Size not available in lookup response - } - - return files - - async def generate_download_link(self, hash, index): - try: - response = await self.session.post( - f"{self.api_url}/link/generate", - headers={**self.headers, "Content-Type": "application/json"}, - json={"url": f"magnet:?xt=urn:btih:{hash}"}, - ) - data = await response.json() - - if not data or "files" not in data: - return None - - video_files = [ - f - for f in data["files"] - if is_video(f["filename"]) and "sample" not in f["filename"].lower() - ] - - if not video_files: - return None - - if "|" in str(index): - season, episode = map(int, index.split("|")) - for file in video_files: - parsed = parse(file["filename"]) - if ( - parsed - and season in parsed.seasons - and episode in parsed.episodes - ): - return file["url"] - - largest_file = max(video_files, key=lambda x: x["size"]) - - return largest_file["url"] - except Exception as e: - logger.warning(f"Error generating link for {hash}|{index}: {e}") diff --git a/comet/debrid/manager.py b/comet/debrid/manager.py index 415348c..cbcc5ed 100644 --- a/comet/debrid/manager.py +++ b/comet/debrid/manager.py @@ -5,7 +5,6 @@ from .premiumize import Premiumize from .torbox import TorBox from .debridlink import DebridLink -from .easydebrid import EasyDebrid def getDebrid(session: aiohttp.ClientSession, config: dict, ip: str): @@ -20,6 +19,4 @@ def getDebrid(session: aiohttp.ClientSession, config: dict, ip: str): elif debrid_service == "torbox": return TorBox(session, debrid_api_key) elif debrid_service == "debridlink": - return DebridLink(session, debrid_api_key) - elif debrid_service == "easydebrid": - return EasyDebrid(session, debrid_api_key, ip) \ No newline at end of file + return DebridLink(session, debrid_api_key) \ No newline at end of file diff --git a/comet/templates/index.html b/comet/templates/index.html index 361b11b..75b6ccc 100644 --- a/comet/templates/index.html +++ b/comet/templates/index.html @@ -542,7 +542,6 @@