From 4d7ac8d62a22bf2453ed6e433f43f8ebdb969e5f Mon Sep 17 00:00:00 2001 From: Davide Marcoli <69892203+davidemarcoli@users.noreply.github.com> Date: Fri, 1 Nov 2024 17:08:36 +0100 Subject: [PATCH] fix: duplicate item after scraping for media that isn't in the database already (#834) --- src/program/db/db_functions.py | 11 +++++++++++ src/routers/secure/scrape.py | 31 +++++++++++++------------------ 2 files changed, 24 insertions(+), 18 deletions(-) diff --git a/src/program/db/db_functions.py b/src/program/db/db_functions.py index 89821e5d..8ae320b7 100644 --- a/src/program/db/db_functions.py +++ b/src/program/db/db_functions.py @@ -61,6 +61,17 @@ def get_item(session, media_item_id, item_type): session.expunge(item) yield item + +def get_media_item_by_imdb_id(imdb_id: str): + """Retrieve a MediaItem by its IMDb ID.""" + from program.media.item import MediaItem + + with db.Session() as session: + return session.execute( + select(MediaItem) + .where(MediaItem.imdb_id == imdb_id) + ).unique().scalar_one_or_none() + def get_parent_ids(media_item_ids: list[int]): """Retrieve the _ids of MediaItems of type 'movie' or 'show' by a list of MediaItem _ids.""" from program.media.item import MediaItem diff --git a/src/routers/secure/scrape.py b/src/routers/secure/scrape.py index 5e546fdd..ae706a46 100644 --- a/src/routers/secure/scrape.py +++ b/src/routers/secure/scrape.py @@ -8,7 +8,7 @@ from sqlalchemy import select from sqlalchemy.orm import selectinload -from program.db.db_functions import get_media_items_by_ids +import program.db.db_functions as db_functions from program.downloaders import Downloader from program.downloaders.shared import hash_from_uri from program.media.item import Episode, MediaItem, Season, Show @@ -252,9 +252,12 @@ async def start_manual_session( if imdb_id: prepared_item = MediaItem({"imdb_id": imdb_id}) - item = next(TraktIndexer().run(prepared_item)) + if db_functions.ensure_item_exists_in_db(prepared_item): + item = db_functions.get_media_item_by_imdb_id(imdb_id) + else: + item = next(TraktIndexer().run(prepared_item)) else: - item = next(get_media_items_by_ids([item_id]), None) + item = next(db_functions.get_media_items_by_ids([item_id]), None) if not item: raise HTTPException(status_code=404, detail="Item not found") @@ -325,22 +328,14 @@ def manual_update_attributes(request: Request, session_id, data: Union[Container if str(session.item_id).startswith("tt"): prepared_item = MediaItem({"imdb_id": session.item_id}) - item = next(TraktIndexer().run(prepared_item)) - db_session.add(item) - db_session.commit() + if db_functions.ensure_item_exists_in_db(prepared_item): + item = db_functions.get_media_item_by_imdb_id(session.item_id) + else: + item = next(TraktIndexer().run(prepared_item)) + db_functions.store_item(item) + item = db_functions.get_media_item_by_imdb_id(session.item_id) else: - item: MediaItem = ( - db_session.execute( - select(MediaItem) - .where(MediaItem._id == session.item_id) - .options( - selectinload(Show.seasons) - .selectinload(Season.episodes) - ) - ) - .unique() - .scalar_one_or_none() - ) + item = db_functions.get_item_from_db(session.item_id) if not item: raise HTTPException(status_code=404, detail="Item not found")