refactor(diary): DeleteReviewDeps, GetMovieSocialPageDeps, GetActivityFeedDeps

This commit is contained in:
2026-06-11 22:37:35 +02:00
parent ddf100cfc2
commit 7bf5c47f5b
18 changed files with 238 additions and 119 deletions

View File

@@ -7,7 +7,7 @@ use domain::{
value_objects::MovieId,
};
use crate::{context::AppContext, diary::queries::GetMovieSocialPageQuery};
use crate::diary::{deps::GetMovieSocialPageDeps, queries::GetMovieSocialPageQuery};
pub struct MovieSocialPageResult {
pub movie: Movie,
@@ -17,23 +17,22 @@ pub struct MovieSocialPageResult {
}
pub async fn execute(
ctx: &AppContext,
deps: &GetMovieSocialPageDeps,
query: GetMovieSocialPageQuery,
) -> Result<MovieSocialPageResult, DomainError> {
let movie_id = MovieId::from_uuid(query.movie_id);
let page = PageParams::new(Some(query.limit), Some(query.offset))?;
let movie = ctx
.repos
let movie = deps
.movie
.get_movie_by_id(&movie_id)
.await?
.ok_or_else(|| DomainError::NotFound(format!("Movie {}", query.movie_id)))?;
let (stats, reviews, profile) = tokio::try_join!(
ctx.repos.diary.get_movie_stats(&movie_id),
ctx.repos.diary.get_movie_social_feed(&movie_id, &page),
ctx.repos.movie_profile.get_by_movie_id(&movie_id),
deps.diary.get_movie_stats(&movie_id),
deps.diary.get_movie_social_feed(&movie_id, &page),
deps.movie_profile.get_by_movie_id(&movie_id),
)?;
Ok(MovieSocialPageResult {