mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-06-09 17:09:22 +00:00
35cbae61bc
* Respond directly with LemmyError Instrument Perform implementations for more precise traces Use ApiError to format JSON errors when messages are present Keep SpanTrace output in LemmyError Display impl * Hide SpanTrace debug output from LemmyError * Don't log when entering spans, only when leaving * Update actix-web * Update actix-rt * Add newline after error info in LemmyError Display impl * Propogate span information to blocking operations * Instrument apub functions * Use skip_all for more instrument attributes, don't skip 'self' in some api actions * Make message a static string * Send proper JSON over websocket * Add 'message' to LemmyError display if present * Use a quieter root span builder, don't pretty-print logs * Keep passwords and emails out of logs * Re-enable logging Login * Instrument feeds * Emit our own errors * Move error log after status code recording * Make Sensitive generic over the inner type * Remove line that logged secrets
83 lines
2.4 KiB
Rust
83 lines
2.4 KiB
Rust
use crate::{
|
|
activities::{generate_activity_id, send_lemmy_activity, verify_activity},
|
|
protocol::activities::following::{accept::AcceptFollowCommunity, follow::FollowCommunity},
|
|
};
|
|
use activitystreams_kinds::activity::AcceptType;
|
|
use lemmy_api_common::blocking;
|
|
use lemmy_apub_lib::{
|
|
data::Data,
|
|
object_id::ObjectId,
|
|
traits::{ActivityHandler, ActorType},
|
|
verify::verify_urls_match,
|
|
};
|
|
use lemmy_db_schema::{source::community::CommunityFollower, traits::Followable};
|
|
use lemmy_utils::LemmyError;
|
|
use lemmy_websocket::LemmyContext;
|
|
|
|
impl AcceptFollowCommunity {
|
|
#[tracing::instrument(skip_all)]
|
|
pub async fn send(
|
|
follow: FollowCommunity,
|
|
context: &LemmyContext,
|
|
request_counter: &mut i32,
|
|
) -> Result<(), LemmyError> {
|
|
let community = follow.object.dereference_local(context).await?;
|
|
let person = follow
|
|
.actor
|
|
.clone()
|
|
.dereference(context, request_counter)
|
|
.await?;
|
|
let accept = AcceptFollowCommunity {
|
|
actor: ObjectId::new(community.actor_id()),
|
|
object: follow,
|
|
kind: AcceptType::Accept,
|
|
id: generate_activity_id(
|
|
AcceptType::Accept,
|
|
&context.settings().get_protocol_and_hostname(),
|
|
)?,
|
|
unparsed: Default::default(),
|
|
};
|
|
let inbox = vec![person.inbox_url()];
|
|
send_lemmy_activity(context, &accept, &accept.id, &community, inbox, true).await
|
|
}
|
|
}
|
|
|
|
/// Handle accepted follows
|
|
#[async_trait::async_trait(?Send)]
|
|
impl ActivityHandler for AcceptFollowCommunity {
|
|
type DataType = LemmyContext;
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn verify(
|
|
&self,
|
|
context: &Data<LemmyContext>,
|
|
request_counter: &mut i32,
|
|
) -> Result<(), LemmyError> {
|
|
verify_activity(&self.id, self.actor.inner(), &context.settings())?;
|
|
verify_urls_match(self.actor.inner(), self.object.object.inner())?;
|
|
self.object.verify(context, request_counter).await?;
|
|
Ok(())
|
|
}
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn receive(
|
|
self,
|
|
context: &Data<LemmyContext>,
|
|
request_counter: &mut i32,
|
|
) -> Result<(), LemmyError> {
|
|
let person = self.actor.dereference(context, request_counter).await?;
|
|
let community = self
|
|
.object
|
|
.actor
|
|
.dereference(context, request_counter)
|
|
.await?;
|
|
// This will throw an error if no follow was requested
|
|
blocking(context.pool(), move |conn| {
|
|
CommunityFollower::follow_accepted(conn, person.id, community.id)
|
|
})
|
|
.await??;
|
|
|
|
Ok(())
|
|
}
|
|
}
|