X-Git-Url: http://these/git/?a=blobdiff_plain;f=crates%2Fapub%2Fsrc%2Factivities%2Ffollowing%2Faccept.rs;h=adaad51d14b263d1d41fa2cf07ce4d5814a1a6e1;hb=e9e76549a88cfbdab36f00d302cceabcaaa24f4c;hp=c76263cc0f93ccc29e229e4c9431ce68eea153f6;hpb=f6f169b4eb7542825cf17712b474b6a6ab71cb64;p=lemmy.git diff --git a/crates/apub/src/activities/following/accept.rs b/crates/apub/src/activities/following/accept.rs index c76263cc..adaad51d 100644 --- a/crates/apub/src/activities/following/accept.rs +++ b/crates/apub/src/activities/following/accept.rs @@ -1,102 +1,72 @@ use crate::{ - activities::{ - following::follow::FollowCommunity, - generate_activity_id, - verify_activity, - verify_community, - }, - activity_queue::send_activity_new, - extensions::context::lemmy_context, - fetcher::{community::get_or_fetch_and_upsert_community, person::get_or_fetch_and_upsert_person}, - ActorType, + activities::{generate_activity_id, send_lemmy_activity}, + insert_received_activity, + protocol::activities::following::{accept::AcceptFollow, follow::Follow}, }; -use activitystreams::{ - activity::kind::AcceptType, - base::AnyBase, - primitives::OneOrMany, - unparsed::Unparsed, +use activitypub_federation::{ + config::Data, + kinds::activity::AcceptType, + protocol::verification::verify_urls_match, + traits::{ActivityHandler, Actor}, }; -use lemmy_api_common::blocking; -use lemmy_apub_lib::{verify_urls_match, ActivityFields, ActivityHandler}; -use lemmy_db_queries::{ApubObject, Followable}; -use lemmy_db_schema::source::{ - community::{Community, CommunityFollower}, - person::Person, -}; -use lemmy_utils::LemmyError; -use lemmy_websocket::LemmyContext; -use serde::{Deserialize, Serialize}; +use lemmy_api_common::context::LemmyContext; +use lemmy_db_schema::{source::community::CommunityFollower, traits::Followable}; +use lemmy_utils::error::LemmyError; use url::Url; -#[derive(Clone, Debug, Deserialize, Serialize, ActivityFields)] -#[serde(rename_all = "camelCase")] -pub struct AcceptFollowCommunity { - actor: Url, - to: Url, - object: FollowCommunity, - #[serde(rename = "type")] - kind: AcceptType, - id: Url, - #[serde(rename = "@context")] - context: OneOrMany, - #[serde(flatten)] - unparsed: Unparsed, -} - -impl AcceptFollowCommunity { - pub async fn send(follow: FollowCommunity, context: &LemmyContext) -> Result<(), LemmyError> { - let community_id = follow.object.clone(); - let community = blocking(context.pool(), move |conn| { - Community::read_from_apub_id(conn, &community_id.into()) - }) - .await??; - let person_id = follow.actor().clone(); - let person = blocking(context.pool(), move |conn| { - Person::read_from_apub_id(conn, &person_id.into()) - }) - .await??; - - let accept = AcceptFollowCommunity { - actor: community.actor_id(), - to: person.actor_id(), +impl AcceptFollow { + #[tracing::instrument(skip_all)] + pub async fn send(follow: Follow, context: &Data) -> Result<(), LemmyError> { + let user_or_community = follow.object.dereference_local(context).await?; + let person = follow.actor.clone().dereference(context).await?; + let accept = AcceptFollow { + actor: user_or_community.id().into(), + to: Some([person.id().into()]), object: follow, kind: AcceptType::Accept, - id: generate_activity_id(AcceptType::Accept)?, - context: lemmy_context(), - unparsed: Default::default(), + id: generate_activity_id( + AcceptType::Accept, + &context.settings().get_protocol_and_hostname(), + )?, }; - let inbox = vec![person.inbox_url.into()]; - send_activity_new(context, &accept, &accept.id, &community, inbox, true).await + let inbox = vec![person.shared_inbox_or_inbox()]; + send_lemmy_activity(context, accept, &user_or_community, inbox, true).await } } + /// Handle accepted follows -#[async_trait::async_trait(?Send)] -impl ActivityHandler for AcceptFollowCommunity { - async fn verify( - &self, - context: &LemmyContext, - request_counter: &mut i32, - ) -> Result<(), LemmyError> { - verify_activity(self)?; - verify_urls_match(&self.to, self.object.actor())?; - verify_urls_match(&self.actor, &self.object.to)?; - verify_community(&self.actor, context, request_counter).await?; - self.object.verify(context, request_counter).await?; +#[async_trait::async_trait] +impl ActivityHandler for AcceptFollow { + type DataType = LemmyContext; + type Error = LemmyError; + + fn id(&self) -> &Url { + &self.id + } + + fn actor(&self) -> &Url { + self.actor.inner() + } + + #[tracing::instrument(skip_all)] + async fn verify(&self, context: &Data) -> Result<(), LemmyError> { + insert_received_activity(&self.id, context).await?; + verify_urls_match(self.actor.inner(), self.object.object.inner())?; + self.object.verify(context).await?; + if let Some(to) = &self.to { + verify_urls_match(to[0].inner(), self.object.actor.inner())?; + } Ok(()) } - async fn receive( - self, - context: &LemmyContext, - request_counter: &mut i32, - ) -> Result<(), LemmyError> { - let actor = get_or_fetch_and_upsert_community(&self.actor, context, request_counter).await?; - let to = get_or_fetch_and_upsert_person(&self.to, context, request_counter).await?; + #[tracing::instrument(skip_all)] + async fn receive(self, context: &Data) -> Result<(), LemmyError> { + let community = self.actor.dereference(context).await?; + let person = self.object.actor.dereference(context).await?; // This will throw an error if no follow was requested - blocking(context.pool(), move |conn| { - CommunityFollower::follow_accepted(conn, actor.id, to.id) - }) - .await??; + let community_id = community.id; + let person_id = person.id; + CommunityFollower::follow_accepted(&mut context.pool(), community_id, person_id).await?; Ok(()) }