From 15f318839601d7c16b1557dff6a4fbfb7a6ca237 Mon Sep 17 00:00:00 2001 From: alemi Date: Fri, 27 Dec 2024 16:30:51 +0100 Subject: [PATCH] feat: broadcasts get sent to relays --- upub/worker/src/outbound.rs | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/upub/worker/src/outbound.rs b/upub/worker/src/outbound.rs index 470b62f..13a0220 100644 --- a/upub/worker/src/outbound.rs +++ b/upub/worker/src/outbound.rs @@ -170,8 +170,21 @@ pub async fn process(ctx: Context, job: &model::job::Model) -> crate::JobResult< // TODO very important that we limit Update activities!!! otherwise with .process() local users // can change their document completely - let targets = activity.addressed(); + let mut targets = activity.addressed(); + let is_broadcast = activity.to().flat().into_iter().any(|x| apb::target::is_public(&x.id().unwrap_or_default())); ctx.process(activity, &tx).await?; + + if is_broadcast { + for relay in upub::Query::related(None, Some(ctx.actor().internal), false) + .select_only() + .select_column(upub::model::actor::Column::Id) + .into_tuple::() + .all(&tx) + .await? + { + targets.push(relay); + } + } ctx.deliver(targets, &job.activity, &job.actor, &tx).await?; tx.commit().await?;