From aab0b918bd205b668ce15510c13d672efb5ed923 Mon Sep 17 00:00:00 2001 From: Goldy <153996346+g0ldyy@users.noreply.github.com> Date: Wed, 24 Jul 2024 19:31:17 +0200 Subject: [PATCH] feat: debrid download links are now cached for 1h (massive speed improvement) --- comet/api/stream.py | 34 +++++++++++++++++++++++++++++----- comet/utils/db.py | 3 +++ 2 files changed, 32 insertions(+), 5 deletions(-) diff --git a/comet/api/stream.py b/comet/api/stream.py index 63dcc62..701ef2c 100644 --- a/comet/api/stream.py +++ b/comet/api/stream.py @@ -377,10 +377,33 @@ async def playback(request: Request, b64config: str, hash: str, index: str): return FileResponse("comet/assets/invalidconfig.mp4") async with aiohttp.ClientSession() as session: - debrid = getDebrid(session, config) - download_link = await debrid.generate_download_link(hash, index) + # Check for cached download link + cached_link = await database.fetch_one( + f"SELECT link, timestamp FROM download_links WHERE debrid_key = '{config['debridApiKey']}' AND hash = '{hash}' AND `index` = '{index}'" + ) + + current_time = time.time() + download_link = None + if cached_link: + link = cached_link["link"] + timestamp = cached_link["timestamp"] + + if current_time - timestamp < 3600: + download_link = link + else: + # Cache expired, remove old entry + await database.execute( + f"DELETE FROM download_links WHERE debrid_key = '{config['debridApiKey']}' AND hash = '{hash}' AND `index` = '{index}'" + ) + if not download_link: - return FileResponse("comet/assets/uncached.mp4") + debrid = getDebrid(session, config) + download_link = await debrid.generate_download_link(hash, index) + if not download_link: + return FileResponse("comet/assets/uncached.mp4") + + # Cache the new download link + await database.execute("INSERT OR REPLACE INTO download_links (debrid_key, hash, `index`, link, timestamp) VALUES (:debrid_key, :hash, :index, :link, :timestamp)", {"debrid_key": config["debridApiKey"], "hash": hash, "index": index, "link": download_link, "timestamp": current_time}) proxy = ( debrid.proxy if config["debridService"] == "alldebrid" else None @@ -407,7 +430,8 @@ async def stream_content(self, headers: dict): async def close(self): if self.response is not None: await self.response.aclose() - await self.client.aclose() + if self.client is not None: + await self.client.aclose() range_header = request.headers.get("range", "bytes=0-") @@ -423,7 +447,7 @@ async def close(self): "Content-Length": response.headers["Content-Length"], "Accept-Ranges": "bytes", }, - background=BackgroundTask(await streamer.close()), + background=BackgroundTask(streamer.close), ) return FileResponse("comet/assets/uncached.mp4") diff --git a/comet/utils/db.py b/comet/utils/db.py index 3347c99..0dfcc60 100644 --- a/comet/utils/db.py +++ b/comet/utils/db.py @@ -15,6 +15,9 @@ async def setup_database(): await database.execute( "CREATE TABLE IF NOT EXISTS cache (cacheKey BLOB PRIMARY KEY, timestamp INTEGER, results TEXT)" ) + await database.execute( + "CREATE TABLE IF NOT EXISTS download_links (debrid_key TEXT, hash TEXT, `index` TEXT, link TEXT, timestamp INTEGER, PRIMARY KEY (debrid_key, hash, `index`))" + ) except Exception as e: logger.error(f"Error setting up the database: {e}")