]> Untitled Git - lemmy.git/blob - crates/api/src/post/mark_read.rs
Merge pull request #2593 from LemmyNet/refactor-notifications
[lemmy.git] / crates / api / src / post / mark_read.rs
1 use crate::Perform;
2 use actix_web::web::Data;
3 use lemmy_api_common::{
4   context::LemmyContext,
5   post::{MarkPostAsRead, PostResponse},
6   utils::{get_local_user_view_from_jwt, mark_post_as_read, mark_post_as_unread},
7 };
8 use lemmy_db_views::structs::PostView;
9 use lemmy_utils::{error::LemmyError, ConnectionId};
10
11 #[async_trait::async_trait(?Send)]
12 impl Perform for MarkPostAsRead {
13   type Response = PostResponse;
14
15   #[tracing::instrument(skip(context, _websocket_id))]
16   async fn perform(
17     &self,
18     context: &Data<LemmyContext>,
19     _websocket_id: Option<ConnectionId>,
20   ) -> Result<Self::Response, LemmyError> {
21     let data = self;
22     let local_user_view =
23       get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
24
25     let post_id = data.post_id;
26     let person_id = local_user_view.person.id;
27
28     // Mark the post as read / unread
29     if data.read {
30       mark_post_as_read(person_id, post_id, context.pool()).await?;
31     } else {
32       mark_post_as_unread(person_id, post_id, context.pool()).await?;
33     }
34
35     // Fetch it
36     let post_view = PostView::read(context.pool(), post_id, Some(person_id)).await?;
37
38     let res = Self::Response { post_view };
39
40     Ok(res)
41   }
42 }