From 70f3c2a5c5207edc959180e9e731c5e027b7517a Mon Sep 17 00:00:00 2001 From: Mario Date: Wed, 17 Jul 2024 14:25:14 +0200 Subject: [PATCH] refactor: [#615] download torrent handler now calls the torrent service to get the canonical infohash --- src/web/api/server/v1/contexts/torrent/handlers.rs | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/src/web/api/server/v1/contexts/torrent/handlers.rs b/src/web/api/server/v1/contexts/torrent/handlers.rs index 5b38d3e4..98eae53b 100644 --- a/src/web/api/server/v1/contexts/torrent/handlers.rs +++ b/src/web/api/server/v1/contexts/torrent/handlers.rs @@ -77,7 +77,9 @@ pub async fn download_torrent_handler( debug!("Downloading torrent: {:?}", info_hash.to_hex_string()); - if let Some(redirect_response) = redirect_to_download_url_using_canonical_info_hash_if_needed(&app_data, &info_hash).await { + if let Some(redirect_response) = + redirect_to_download_url_using_canonical_info_hash_if_needed(&app_data, &info_hash, opt_user_id).await + { debug!("Redirecting to URL with canonical info-hash"); redirect_response } else { @@ -101,12 +103,9 @@ pub async fn download_torrent_handler( async fn redirect_to_download_url_using_canonical_info_hash_if_needed( app_data: &Arc, info_hash: &InfoHash, + opt_user_id: Option, ) -> Option { - match app_data - .torrent_info_hash_repository - .find_canonical_info_hash_for(info_hash) - .await - { + match app_data.torrent_service.get_canonical_info_hash(info_hash, opt_user_id).await { Ok(Some(canonical_info_hash)) => { if canonical_info_hash != *info_hash { return Some(