Merge branch 'reachability' into 'develop'

Fix reachability based on results of publishing attempts

See merge request pleroma/pleroma!4231
This commit is contained in:
feld 2024-08-19 16:49:08 +00:00
commit 08a444f6c3
3 changed files with 14 additions and 11 deletions

View file

@ -0,0 +1 @@
Address case where instance reachability status couldn't be updated

View file

@ -148,12 +148,17 @@ defmodule Pleroma.Web.ActivityPub.Publisher do
{"digest", p.digest} {"digest", p.digest}
] ]
) do ) do
maybe_set_reachable(p.unreachable_since, p.inbox) if not is_nil(p.unreachable_since) do
Instances.set_reachable(p.inbox)
end
result result
else else
{_post_result, %{status: code} = response} = e -> {_post_result, %{status: code} = response} = e ->
maybe_set_unreachable(p.unreachable_since, p.inbox) if is_nil(p.unreachable_since) do
Instances.set_unreachable(p.inbox)
end
Logger.metadata(activity: p.activity_id, inbox: p.inbox, status: code) Logger.metadata(activity: p.activity_id, inbox: p.inbox, status: code)
Logger.error("Publisher failed to inbox #{p.inbox} with status #{code}") Logger.error("Publisher failed to inbox #{p.inbox} with status #{code}")
@ -174,7 +179,10 @@ defmodule Pleroma.Web.ActivityPub.Publisher do
connection_pool_snooze() connection_pool_snooze()
e -> e ->
maybe_set_unreachable(p.unreachable_since, p.inbox) if is_nil(p.unreachable_since) do
Instances.set_unreachable(p.inbox)
end
Logger.metadata(activity: p.activity_id, inbox: p.inbox) Logger.metadata(activity: p.activity_id, inbox: p.inbox)
Logger.error("Publisher failed to inbox #{p.inbox} #{inspect(e)}") Logger.error("Publisher failed to inbox #{p.inbox} #{inspect(e)}")
{:error, e} {:error, e}
@ -183,12 +191,6 @@ defmodule Pleroma.Web.ActivityPub.Publisher do
defp connection_pool_snooze, do: {:snooze, 3} defp connection_pool_snooze, do: {:snooze, 3}
defp maybe_set_reachable(%NaiveDateTime{}, inbox), do: Instances.set_reachable(inbox)
defp maybe_set_reachable(_, _), do: :ok
defp maybe_set_unreachable(nil, inbox), do: Instances.set_unreachable(inbox)
defp maybe_set_unreachable(%NaiveDateTime{}, _), do: :ok
defp signature_host(%URI{port: port, scheme: scheme, host: host}) do defp signature_host(%URI{port: port, scheme: scheme, host: host}) do
if port == URI.default_port(scheme) do if port == URI.default_port(scheme) do
host host

View file

@ -180,7 +180,7 @@ defmodule Pleroma.Web.ActivityPub.PublisherTest do
Publisher.prepare_one(%{ Publisher.prepare_one(%{
inbox: inbox, inbox: inbox,
activity_id: activity.id, activity_id: activity.id,
unreachable_since: NaiveDateTime.utc_now() unreachable_since: NaiveDateTime.utc_now() |> NaiveDateTime.to_string()
}) })
|> Publisher.publish_one() |> Publisher.publish_one()
@ -269,7 +269,7 @@ defmodule Pleroma.Web.ActivityPub.PublisherTest do
Publisher.prepare_one(%{ Publisher.prepare_one(%{
inbox: inbox, inbox: inbox,
activity_id: activity.id, activity_id: activity.id,
unreachable_since: NaiveDateTime.utc_now() unreachable_since: NaiveDateTime.utc_now() |> NaiveDateTime.to_string()
}) })
|> Publisher.publish_one() |> Publisher.publish_one()
end) =~ "connrefused" end) =~ "connrefused"