diff options
| -rw-r--r-- | lib/pleroma/web/activity_pub/publisher.ex | 55 | 
1 files changed, 30 insertions, 25 deletions
| diff --git a/lib/pleroma/web/activity_pub/publisher.ex b/lib/pleroma/web/activity_pub/publisher.ex index 4ea37fc7b..4073d3d63 100644 --- a/lib/pleroma/web/activity_pub/publisher.ex +++ b/lib/pleroma/web/activity_pub/publisher.ex @@ -9,6 +9,7 @@ defmodule Pleroma.Web.ActivityPub.Publisher do    alias Pleroma.HTTP    alias Pleroma.Instances    alias Pleroma.Object +  alias Pleroma.Repo    alias Pleroma.User    alias Pleroma.Web.ActivityPub.Relay    alias Pleroma.Web.ActivityPub.Transmogrifier @@ -188,31 +189,35 @@ defmodule Pleroma.Web.ActivityPub.Publisher do      recipients = recipients(actor, activity) -    recipients -    |> Enum.filter(&User.ap_enabled?/1) -    |> Enum.map(fn %{source_data: data} -> data["inbox"] end) -    |> Enum.filter(fn inbox -> should_federate?(inbox, public) end) -    |> Instances.filter_reachable() -    |> Enum.each(fn {inbox, unreachable_since} -> -      %User{ap_id: ap_id} = -        Enum.find(recipients, fn %{source_data: data} -> data["inbox"] == inbox end) - -      # Get all the recipients on the same host and add them to cc. Otherwise, a remote -      # instance would only accept a first message for the first recipient and ignore the rest. -      cc = get_cc_ap_ids(ap_id, recipients) - -      json = -        data -        |> Map.put("cc", cc) -        |> Jason.encode!() - -      Pleroma.Web.Federator.Publisher.enqueue_one(__MODULE__, %{ -        inbox: inbox, -        json: json, -        actor_id: actor.id, -        id: activity.data["id"], -        unreachable_since: unreachable_since -      }) +    inboxes = +      recipients +      |> Enum.filter(&User.ap_enabled?/1) +      |> Enum.map(fn %{source_data: data} -> data["inbox"] end) +      |> Enum.filter(fn inbox -> should_federate?(inbox, public) end) +      |> Instances.filter_reachable() + +    Repo.checkout(fn -> +      Enum.each(inboxes, fn {inbox, unreachable_since} -> +        %User{ap_id: ap_id} = +          Enum.find(recipients, fn %{source_data: data} -> data["inbox"] == inbox end) + +        # Get all the recipients on the same host and add them to cc. Otherwise, a remote +        # instance would only accept a first message for the first recipient and ignore the rest. +        cc = get_cc_ap_ids(ap_id, recipients) + +        json = +          data +          |> Map.put("cc", cc) +          |> Jason.encode!() + +        Pleroma.Web.Federator.Publisher.enqueue_one(__MODULE__, %{ +          inbox: inbox, +          json: json, +          actor_id: actor.id, +          id: activity.data["id"], +          unreachable_since: unreachable_since +        }) +      end)      end)    end | 
