1 use crate::PerformCrud;
2 use actix_web::web::Data;
3 use lemmy_api_common::{
5 get_local_user_view_from_jwt,
6 person::{EditPrivateMessage, PrivateMessageResponse},
8 use lemmy_apub::protocol::activities::{
9 private_message::create_or_update::CreateOrUpdatePrivateMessage,
12 use lemmy_db_schema::{source::private_message::PrivateMessage, traits::Crud};
13 use lemmy_utils::{utils::remove_slurs, ConnectionId, LemmyError};
14 use lemmy_websocket::{send::send_pm_ws_message, LemmyContext, UserOperationCrud};
16 #[async_trait::async_trait(?Send)]
17 impl PerformCrud for EditPrivateMessage {
18 type Response = PrivateMessageResponse;
20 #[tracing::instrument(skip(self, context, websocket_id))]
23 context: &Data<LemmyContext>,
24 websocket_id: Option<ConnectionId>,
25 ) -> Result<PrivateMessageResponse, LemmyError> {
26 let data: &EditPrivateMessage = self;
28 get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
30 // Checking permissions
31 let private_message_id = data.private_message_id;
32 let orig_private_message = blocking(context.pool(), move |conn| {
33 PrivateMessage::read(conn, private_message_id)
36 if local_user_view.person.id != orig_private_message.creator_id {
37 return Err(LemmyError::from_message("no_private_message_edit_allowed"));
41 let content_slurs_removed = remove_slurs(&data.content, &context.settings().slur_regex());
42 let private_message_id = data.private_message_id;
43 let updated_private_message = blocking(context.pool(), move |conn| {
44 PrivateMessage::update_content(conn, private_message_id, &content_slurs_removed)
47 .map_err(LemmyError::from)
48 .map_err(|e| e.with_message("couldnt_update_private_message"))?;
50 // Send the apub update
51 CreateOrUpdatePrivateMessage::send(
52 updated_private_message.into(),
53 &local_user_view.person.into(),
54 CreateOrUpdateType::Update,
59 let op = UserOperationCrud::EditPrivateMessage;
60 send_pm_ws_message(data.private_message_id, op, websocket_id, context).await