diff options
| -rw-r--r-- | changelog.d/publisher-reachability.fix | 1 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/publisher.ex | 20 | 
2 files changed, 12 insertions, 9 deletions
| diff --git a/changelog.d/publisher-reachability.fix b/changelog.d/publisher-reachability.fix new file mode 100644 index 000000000..3f50be581 --- /dev/null +++ b/changelog.d/publisher-reachability.fix @@ -0,0 +1 @@ +Address case where instance reachability status couldn't be updated diff --git a/lib/pleroma/web/activity_pub/publisher.ex b/lib/pleroma/web/activity_pub/publisher.ex index 5cd982c6a..0de3a0d43 100644 --- a/lib/pleroma/web/activity_pub/publisher.ex +++ b/lib/pleroma/web/activity_pub/publisher.ex @@ -148,12 +148,17 @@ defmodule Pleroma.Web.ActivityPub.Publisher do                 {"digest", p.digest}               ]             ) do -      maybe_set_reachable(p.unreachable_since, p.inbox) +      if not is_nil(p.unreachable_since) do +        Instances.set_reachable(p.inbox) +      end        result      else        {_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.error("Publisher failed to inbox #{p.inbox} with status #{code}") @@ -174,7 +179,10 @@ defmodule Pleroma.Web.ActivityPub.Publisher do          connection_pool_snooze()        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.error("Publisher failed to inbox #{p.inbox} #{inspect(e)}")          {:error, e} @@ -183,12 +191,6 @@ defmodule Pleroma.Web.ActivityPub.Publisher do    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      if port == URI.default_port(scheme) do        host | 
