3 community::{announce::AnnouncableActivities, send_to_community},
7 verify_delete_activity,
14 context::lemmy_context,
15 fetcher::object_id::ObjectId,
17 use activitystreams::{
18 activity::kind::UndoType,
20 primitives::OneOrMany,
24 use lemmy_api_common::blocking;
27 traits::{ActivityFields, ActivityHandler, ActorType},
30 use lemmy_db_schema::source::{comment::Comment, community::Community, person::Person, post::Post};
31 use lemmy_utils::LemmyError;
32 use lemmy_websocket::{
33 send::{send_comment_ws_message_simple, send_community_ws_message, send_post_ws_message},
37 use serde::{Deserialize, Serialize};
40 #[derive(Clone, Debug, Deserialize, Serialize, ActivityFields)]
41 #[serde(rename_all = "camelCase")]
42 pub struct UndoDelete {
43 actor: ObjectId<Person>,
46 cc: [ObjectId<Community>; 1],
47 #[serde(rename = "type")]
50 #[serde(rename = "@context")]
51 context: OneOrMany<AnyBase>,
56 #[async_trait::async_trait(?Send)]
57 impl ActivityHandler for UndoDelete {
58 type DataType = LemmyContext;
61 context: &Data<LemmyContext>,
62 request_counter: &mut i32,
63 ) -> Result<(), LemmyError> {
64 verify_activity(self, &context.settings())?;
65 self.object.verify(context, request_counter).await?;
66 verify_delete_activity(
70 self.object.summary.is_some(),
80 context: &Data<LemmyContext>,
81 request_counter: &mut i32,
82 ) -> Result<(), LemmyError> {
83 if self.object.summary.is_some() {
84 UndoDelete::receive_undo_remove_action(&self.object.object, context).await
86 receive_delete_action(
90 community: UserOperationCrud::EditCommunity,
91 post: UserOperationCrud::EditPost,
92 comment: UserOperationCrud::EditComment,
104 pub(in crate::activities::deletion) async fn send(
106 community: &Community,
108 summary: Option<String>,
109 context: &LemmyContext,
110 ) -> Result<(), LemmyError> {
111 let object = Delete::new(actor, community, object_id, summary, context)?;
113 let id = generate_activity_id(
115 &context.settings().get_protocol_and_hostname(),
117 let undo = UndoDelete {
118 actor: ObjectId::new(actor.actor_id()),
119 to: [PublicUrl::Public],
121 cc: [ObjectId::new(community.actor_id())],
122 kind: UndoType::Undo,
124 context: lemmy_context(),
125 unparsed: Default::default(),
128 let activity = AnnouncableActivities::UndoDelete(undo);
129 send_to_community(activity, &id, actor, community, vec![], context).await
132 pub(in crate::activities) async fn receive_undo_remove_action(
134 context: &LemmyContext,
135 ) -> Result<(), LemmyError> {
136 use UserOperationCrud::*;
137 match DeletableObjects::read_from_db(object, context).await? {
138 DeletableObjects::Community(community) => {
140 return Err(anyhow!("Only local admin can restore community").into());
142 let deleted_community = blocking(context.pool(), move |conn| {
143 Community::update_removed(conn, community.id, false)
146 send_community_ws_message(deleted_community.id, EditCommunity, None, None, context).await?;
148 DeletableObjects::Post(post) => {
149 let removed_post = blocking(context.pool(), move |conn| {
150 Post::update_removed(conn, post.id, false)
153 send_post_ws_message(removed_post.id, EditPost, None, None, context).await?;
155 DeletableObjects::Comment(comment) => {
156 let removed_comment = blocking(context.pool(), move |conn| {
157 Comment::update_removed(conn, comment.id, false)
160 send_comment_ws_message_simple(removed_comment.id, EditComment, context).await?;