]> Untitled Git - lemmy.git/blob - crates/api_crud/src/private_message/read.rs
Dont return error in case optional auth is invalid (#2879)
[lemmy.git] / crates / api_crud / src / private_message / read.rs
1 use crate::PerformCrud;
2 use actix_web::web::Data;
3 use lemmy_api_common::{
4   context::LemmyContext,
5   private_message::{GetPrivateMessages, PrivateMessagesResponse},
6   utils::local_user_view_from_jwt,
7 };
8 use lemmy_db_views::private_message_view::PrivateMessageQuery;
9 use lemmy_utils::{error::LemmyError, ConnectionId};
10
11 #[async_trait::async_trait(?Send)]
12 impl PerformCrud for GetPrivateMessages {
13   type Response = PrivateMessagesResponse;
14
15   #[tracing::instrument(skip(self, context, _websocket_id))]
16   async fn perform(
17     &self,
18     context: &Data<LemmyContext>,
19     _websocket_id: Option<ConnectionId>,
20   ) -> Result<PrivateMessagesResponse, LemmyError> {
21     let data: &GetPrivateMessages = self;
22     let local_user_view = local_user_view_from_jwt(data.auth.as_ref(), context).await?;
23     let person_id = local_user_view.person.id;
24
25     let page = data.page;
26     let limit = data.limit;
27     let unread_only = data.unread_only;
28     let mut messages = PrivateMessageQuery::builder()
29       .pool(context.pool())
30       .recipient_id(person_id)
31       .page(page)
32       .limit(limit)
33       .unread_only(unread_only)
34       .build()
35       .list()
36       .await?;
37
38     // Messages sent by ourselves should be marked as read. The `read` column in database is only
39     // for the recipient, and shouldnt be exposed to sender.
40     messages.iter_mut().for_each(|pmv| {
41       if pmv.creator.id == person_id {
42         pmv.private_message.read = true
43       }
44     });
45
46     Ok(PrivateMessagesResponse {
47       private_messages: messages,
48     })
49   }
50 }