2 activities::{generate_activity_id, send_lemmy_activity, verify_is_public, verify_person},
4 objects::{instance::remote_instance_inboxes, person::ApubPerson},
5 protocol::activities::deletion::delete_user::DeleteUser,
7 use activitypub_federation::{
8 core::object_id::ObjectId,
10 traits::ActivityHandler,
11 utils::verify_urls_match,
13 use activitystreams_kinds::{activity::DeleteType, public};
14 use lemmy_api_common::utils::delete_user_account;
15 use lemmy_utils::error::LemmyError;
16 use lemmy_websocket::LemmyContext;
19 /// This can be separate from Delete activity because it doesn't need to be handled in shared inbox
20 /// (cause instance actor doesn't have shared inbox).
21 #[async_trait::async_trait(?Send)]
22 impl ActivityHandler for DeleteUser {
23 type DataType = LemmyContext;
24 type Error = LemmyError;
26 fn id(&self) -> &Url {
30 fn actor(&self) -> &Url {
36 context: &Data<LemmyContext>,
37 request_counter: &mut i32,
38 ) -> Result<(), LemmyError> {
39 verify_is_public(&self.to, &[])?;
40 verify_person(&self.actor, context, request_counter).await?;
41 verify_urls_match(self.actor.inner(), self.object.inner())?;
47 context: &Data<LemmyContext>,
48 request_counter: &mut i32,
49 ) -> Result<(), LemmyError> {
52 .dereference(context, local_instance(context), request_counter)
66 #[tracing::instrument(skip_all)]
67 pub async fn send(actor: &ApubPerson, context: &LemmyContext) -> Result<(), LemmyError> {
68 let actor_id = ObjectId::new(actor.actor_id.clone());
69 let id = generate_activity_id(
71 &context.settings().get_protocol_and_hostname(),
73 let delete = DeleteUser {
74 actor: actor_id.clone(),
77 kind: DeleteType::Delete,
82 let inboxes = remote_instance_inboxes(context.pool()).await?;
83 send_lemmy_activity(context, delete, actor, inboxes, true).await?;