mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-03 13:58:41 +00:00
Merge branch 'publisher' into 'develop'
Discard some failed publisher jobs See merge request pleroma/pleroma!4022
This commit is contained in:
commit
f74f5e0a56
4 changed files with 20 additions and 4 deletions
1
changelog.d/publisher_discard.change
Normal file
1
changelog.d/publisher_discard.change
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Activity publishing failures will prevent the job from retrying if the publishing request returns a 403 or 410
|
1
changelog.d/publisher_log.change
Normal file
1
changelog.d/publisher_log.change
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Publisher errors will now emit logs indicating the inbox that was not available for delivery.
|
|
@ -117,10 +117,23 @@ defmodule Pleroma.Web.ActivityPub.Publisher do
|
||||||
|
|
||||||
result
|
result
|
||||||
else
|
else
|
||||||
{_post_result, response} = e ->
|
{_post_result, %{status: code} = response} = e ->
|
||||||
unless params[:unreachable_since], do: Instances.set_unreachable(inbox)
|
unless params[:unreachable_since], do: Instances.set_unreachable(inbox)
|
||||||
Logger.error("Failed to publish activity #{id} #{inspect(e)}")
|
Logger.metadata(activity: id, inbox: inbox, status: code)
|
||||||
{:error, response}
|
Logger.error("Publisher failed to inbox #{inbox} with status #{code}")
|
||||||
|
|
||||||
|
case response do
|
||||||
|
%{status: 403} -> {:discard, :forbidden}
|
||||||
|
%{status: 404} -> {:discard, :not_found}
|
||||||
|
%{status: 410} -> {:discard, :not_found}
|
||||||
|
_ -> {:error, e}
|
||||||
|
end
|
||||||
|
|
||||||
|
e ->
|
||||||
|
unless params[:unreachable_since], do: Instances.set_unreachable(inbox)
|
||||||
|
Logger.metadata(activity: id, inbox: inbox)
|
||||||
|
Logger.error("Publisher failed to inbox #{inbox} #{inspect(e)}")
|
||||||
|
{:error, e}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -212,7 +212,8 @@ defmodule Pleroma.Web.ActivityPub.PublisherTest do
|
||||||
actor = insert(:user)
|
actor = insert(:user)
|
||||||
inbox = "http://404.site/users/nick1/inbox"
|
inbox = "http://404.site/users/nick1/inbox"
|
||||||
|
|
||||||
assert {:error, _} = Publisher.publish_one(%{inbox: inbox, json: "{}", actor: actor, id: 1})
|
assert {:discard, _} =
|
||||||
|
Publisher.publish_one(%{inbox: inbox, json: "{}", actor: actor, id: 1})
|
||||||
|
|
||||||
assert called(Instances.set_unreachable(inbox))
|
assert called(Instances.set_unreachable(inbox))
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue