mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2024-12-23 08:36:29 +00:00
ActivtyPub Delivery: Use shared inbox if possible.
This commit is contained in:
parent
7b26443a76
commit
c2d0cb1a29
1 changed files with 11 additions and 9 deletions
|
@ -256,18 +256,20 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do
|
|||
def publish(actor, activity) do
|
||||
{:ok, followers} = User.get_followers(actor)
|
||||
|
||||
remote_users = Pleroma.Web.Salmon.remote_users(activity) ++ followers
|
||||
remote_inboxes = Pleroma.Web.Salmon.remote_users(activity) ++ followers
|
||||
|> Enum.filter(fn (user) -> User.ap_enabled?(user) end)
|
||||
|> Enum.map(fn (%{info: %{"source_data" => data}}) ->
|
||||
(data["endpoints"] && data["endpoints"]["sharedInbox"]) ||data["inbox"]
|
||||
end)
|
||||
|> Enum.uniq
|
||||
|
||||
{:ok, data} = Transmogrifier.prepare_outgoing(activity.data)
|
||||
Enum.each remote_users, fn(user) ->
|
||||
if user.info["ap_enabled"] do
|
||||
inbox = user.info["source_data"]["inbox"]
|
||||
|
||||
Enum.each remote_inboxes, fn(inbox) ->
|
||||
Logger.info("Federating #{activity.data["id"]} to #{inbox}")
|
||||
host = URI.parse(inbox).host
|
||||
signature = Pleroma.Web.HTTPSignatures.sign(actor, %{host: host})
|
||||
@httpoison.post(inbox, Poison.encode!(data), [{"Content-Type", "application/activity+json"}, {"signature", signature}])
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue