-
-
Notifications
You must be signed in to change notification settings - Fork 62
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix: api manual scraping fixes #915
Changes from all commits
3c095f2
3f74ee5
e318f93
c779b68
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
@@ -19,6 +19,7 @@ | |||||||||||||||
from program.services.scrapers import Scraping | ||||||||||||||||
from program.services.scrapers.shared import rtn | ||||||||||||||||
from program.types import Event | ||||||||||||||||
from program.services.downloaders.models import TorrentContainer, TorrentInfo | ||||||||||||||||
|
||||||||||||||||
|
||||||||||||||||
class Stream(BaseModel): | ||||||||||||||||
|
@@ -38,8 +39,8 @@ class StartSessionResponse(BaseModel): | |||||||||||||||
message: str | ||||||||||||||||
session_id: str | ||||||||||||||||
torrent_id: str | ||||||||||||||||
torrent_info: dict | ||||||||||||||||
containers: Optional[List[dict]] | ||||||||||||||||
torrent_info: TorrentInfo | ||||||||||||||||
containers: Optional[List[TorrentContainer]] | ||||||||||||||||
expires_at: str | ||||||||||||||||
|
||||||||||||||||
class SelectFilesResponse(BaseModel): | ||||||||||||||||
|
@@ -102,10 +103,10 @@ def __init__(self, id: str, item_id: str, magnet: str): | |||||||||||||||
self.id = id | ||||||||||||||||
self.item_id = item_id | ||||||||||||||||
self.magnet = magnet | ||||||||||||||||
self.torrent_id: Optional[str] = None | ||||||||||||||||
self.torrent_info: Optional[dict] = None | ||||||||||||||||
self.containers: Optional[list] = None | ||||||||||||||||
self.selected_files: Optional[dict] = None | ||||||||||||||||
self.torrent_id: Optional[Union[int, str]] = None | ||||||||||||||||
self.torrent_info: Optional[TorrentInfo] = None | ||||||||||||||||
self.containers: Optional[TorrentContainer] = None | ||||||||||||||||
self.selected_files: Optional[Dict[str, Dict[str, Union[str, int]]]] = None | ||||||||||||||||
self.created_at: datetime = datetime.now() | ||||||||||||||||
self.expires_at: datetime = datetime.now() + timedelta(minutes=5) | ||||||||||||||||
|
||||||||||||||||
|
@@ -218,13 +219,10 @@ def scrape_item(request: Request, id: str) -> ScrapeItemResponse: | |||||||||||||||
.unique() | ||||||||||||||||
.scalar_one_or_none() | ||||||||||||||||
) | ||||||||||||||||
streams = scraper.scrape(item) | ||||||||||||||||
stream_containers = downloader.get_instant_availability([stream for stream in streams.keys()]) | ||||||||||||||||
for stream in streams.keys(): | ||||||||||||||||
if len(stream_containers.get(stream, [])) > 0: | ||||||||||||||||
streams[stream].is_cached = True | ||||||||||||||||
else: | ||||||||||||||||
streams[stream].is_cached = False | ||||||||||||||||
streams: Dict[str, Stream] = scraper.scrape(item) | ||||||||||||||||
for stream in streams.values(): | ||||||||||||||||
container = downloader.get_instant_availability(stream.infohash, item.type) | ||||||||||||||||
stream.is_cached = bool(container and container.cached) | ||||||||||||||||
log_string = item.log_string | ||||||||||||||||
|
||||||||||||||||
return { | ||||||||||||||||
|
@@ -278,23 +276,25 @@ def get_info_hash(magnet: str) -> str: | |||||||||||||||
session = session_manager.create_session(item_id or imdb_id, info_hash) | ||||||||||||||||
|
||||||||||||||||
try: | ||||||||||||||||
torrent_id = downloader.add_torrent(info_hash) | ||||||||||||||||
torrent_info = downloader.get_torrent_info(torrent_id) | ||||||||||||||||
containers = downloader.get_instant_availability([session.magnet]).get(session.magnet, None) | ||||||||||||||||
session_manager.update_session(session.id, torrent_id=torrent_id, torrent_info=torrent_info, containers=containers) | ||||||||||||||||
torrent_id: str = downloader.add_torrent(info_hash) | ||||||||||||||||
torrent_info: TorrentInfo = downloader.get_torrent_info(torrent_id) | ||||||||||||||||
container: Optional[TorrentContainer] = downloader.get_instant_availability(info_hash, item.type) | ||||||||||||||||
session_manager.update_session(session.id, torrent_id=torrent_id, torrent_info=torrent_info, containers=container) | ||||||||||||||||
except Exception as e: | ||||||||||||||||
background_tasks.add_task(session_manager.abort_session, session.id) | ||||||||||||||||
raise HTTPException(status_code=500, detail=str(e)) | ||||||||||||||||
|
||||||||||||||||
return { | ||||||||||||||||
data = { | ||||||||||||||||
"message": "Started manual scraping session", | ||||||||||||||||
"session_id": session.id, | ||||||||||||||||
"torrent_id": torrent_id, | ||||||||||||||||
"torrent_info": torrent_info, | ||||||||||||||||
"containers": containers, | ||||||||||||||||
"containers": [container] if container else None, | ||||||||||||||||
"expires_at": session.expires_at.isoformat() | ||||||||||||||||
} | ||||||||||||||||
|
||||||||||||||||
return StartSessionResponse(**data) | ||||||||||||||||
|
||||||||||||||||
@router.post( | ||||||||||||||||
"/scrape/select_files/{session_id}", | ||||||||||||||||
summary="Select files for torrent id, for this to be instant it requires files to be one of /manual/instant_availability response containers", | ||||||||||||||||
|
@@ -307,7 +307,7 @@ def manual_select_files(request: Request, session_id, files: Container) -> Selec | |||||||||||||||
raise HTTPException(status_code=404, detail="Session not found or expired") | ||||||||||||||||
if not session.torrent_id: | ||||||||||||||||
session_manager.abort_session(session_id) | ||||||||||||||||
raise HTTPException(status_code=500, detail="") | ||||||||||||||||
raise HTTPException(status_code=500, detail="No torrent ID found") | ||||||||||||||||
|
||||||||||||||||
download_type = "uncached" | ||||||||||||||||
if files.model_dump() in session.containers: | ||||||||||||||||
|
@@ -336,7 +336,7 @@ async def manual_update_attributes(request: Request, session_id, data: Union[Con | |||||||||||||||
raise HTTPException(status_code=404, detail="Session not found or expired") | ||||||||||||||||
if not session.item_id: | ||||||||||||||||
session_manager.abort_session(session_id) | ||||||||||||||||
raise HTTPException(status_code=500, detail="") | ||||||||||||||||
raise HTTPException(status_code=500, detail="No item ID found") | ||||||||||||||||
|
||||||||||||||||
with db.Session() as db_session: | ||||||||||||||||
if str(session.item_id).startswith("tt") and not db_functions.get_item_by_external_id(imdb_id=session.item_id) and not db_functions.get_item_by_id(session.item_id): | ||||||||||||||||
|
@@ -357,8 +357,8 @@ async def manual_update_attributes(request: Request, session_id, data: Union[Con | |||||||||||||||
item.reset() | ||||||||||||||||
item.file = data.filename | ||||||||||||||||
item.folder = data.filename | ||||||||||||||||
item.alternative_folder = session.torrent_info["original_filename"] | ||||||||||||||||
item.active_stream = {"infohash": session.magnet, "id": session.torrent_info["id"]} | ||||||||||||||||
item.alternative_folder = session.torrent_info.alternative_filename | ||||||||||||||||
item.active_stream = {"infohash": session.magnet, "id": session.torrent_info.id} | ||||||||||||||||
Comment on lines
+360
to
+361
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ensure Accessing Apply this fix: + if session.torrent_info:
item.alternative_folder = session.torrent_info.alternative_filename
item.active_stream = {"infohash": session.magnet, "id": session.torrent_info.id}
+ else:
+ raise HTTPException(status_code=500, detail="Torrent info is missing in the session") 📝 Committable suggestion
Suggested change
|
||||||||||||||||
torrent = rtn.rank(session.magnet, session.magnet) | ||||||||||||||||
item.streams.append(ItemStream(torrent)) | ||||||||||||||||
item_ids_to_submit.append(item.id) | ||||||||||||||||
|
@@ -377,8 +377,8 @@ async def manual_update_attributes(request: Request, session_id, data: Union[Con | |||||||||||||||
item_episode.reset() | ||||||||||||||||
item_episode.file = episode_data.filename | ||||||||||||||||
item_episode.folder = episode_data.filename | ||||||||||||||||
item_episode.alternative_folder = session.torrent_info["original_filename"] | ||||||||||||||||
item_episode.active_stream = {"infohash": session.magnet, "id": session.torrent_info["id"]} | ||||||||||||||||
item_episode.alternative_folder = session.torrent_info.alternative_filename | ||||||||||||||||
item_episode.active_stream = {"infohash": session.magnet, "id": session.torrent_info.id} | ||||||||||||||||
Comment on lines
+380
to
+381
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add null check for Same as previous comment, ensure Apply this fix: + if session.torrent_info:
item_episode.alternative_folder = session.torrent_info.alternative_filename
item_episode.active_stream = {"infohash": session.magnet, "id": session.torrent_info.id}
+ else:
+ raise HTTPException(status_code=500, detail="Torrent info is missing in the session") 📝 Committable suggestion
Suggested change
|
||||||||||||||||
torrent = rtn.rank(session.magnet, session.magnet) | ||||||||||||||||
item_episode.streams.append(ItemStream(torrent)) | ||||||||||||||||
item_ids_to_submit.append(item_episode.id) | ||||||||||||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Use exception chaining to preserve traceback
When re-raising an exception within an
except
block, use exception chaining to maintain the original traceback information.Apply this fix:
📝 Committable suggestion
🧰 Tools
🪛 Ruff (0.8.0)
285-285: Within an
except
clause, raise exceptions withraise ... from err
orraise ... from None
to distinguish them from errors in exception handling(B904)