X-Git-Url: http://these/git/?a=blobdiff_plain;f=crates%2Fapi%2Fsrc%2Flocal_user%2Fnotifications%2Flist_replies.rs;h=370cd61b472535e70e78ca2ee6e8842a73ed1630;hb=c8063f3267cf2b3622f1fdc69128c6b55feefbbc;hp=643a1c9a867f1f7b8adc853a559e1a11218f76a8;hpb=3053e14be7a47675b621e1c80aa88f4f0a5ce1ae;p=lemmy.git diff --git a/crates/api/src/local_user/notifications/list_replies.rs b/crates/api/src/local_user/notifications/list_replies.rs index 643a1c9a..370cd61b 100644 --- a/crates/api/src/local_user/notifications/list_replies.rs +++ b/crates/api/src/local_user/notifications/list_replies.rs @@ -1,46 +1,40 @@ use crate::Perform; use actix_web::web::Data; use lemmy_api_common::{ + context::LemmyContext, person::{GetReplies, GetRepliesResponse}, - utils::{blocking, get_local_user_view_from_jwt}, + utils::local_user_view_from_jwt, }; -use lemmy_db_views::comment_view::CommentQueryBuilder; -use lemmy_utils::{ConnectionId, LemmyError}; -use lemmy_websocket::LemmyContext; +use lemmy_db_views_actor::comment_reply_view::CommentReplyQuery; +use lemmy_utils::error::LemmyError; #[async_trait::async_trait(?Send)] impl Perform for GetReplies { type Response = GetRepliesResponse; - #[tracing::instrument(skip(context, _websocket_id))] - async fn perform( - &self, - context: &Data, - _websocket_id: Option, - ) -> Result { + #[tracing::instrument(skip(context))] + async fn perform(&self, context: &Data) -> Result { let data: &GetReplies = self; - let local_user_view = - get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?; + let local_user_view = local_user_view_from_jwt(&data.auth, context).await?; let sort = data.sort; let page = data.page; let limit = data.limit; - let unread_only = data.unread_only; - let person_id = local_user_view.person.id; + let unread_only = data.unread_only.unwrap_or_default(); + let person_id = Some(local_user_view.person.id); let show_bot_accounts = local_user_view.local_user.show_bot_accounts; - let replies = blocking(context.pool(), move |conn| { - CommentQueryBuilder::create(conn) - .sort(sort) - .unread_only(unread_only) - .recipient_id(person_id) - .show_bot_accounts(show_bot_accounts) - .my_person_id(person_id) - .page(page) - .limit(limit) - .list() - }) - .await??; + let replies = CommentReplyQuery { + recipient_id: person_id, + my_person_id: person_id, + sort, + unread_only, + show_bot_accounts, + page, + limit, + } + .list(&mut context.pool()) + .await?; Ok(GetRepliesResponse { replies }) }