summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorMark Felder <feld@feld.me>2023-12-26 16:28:05 -0500
committerMark Felder <feld@feld.me>2023-12-26 16:28:05 -0500
commit9c0040124a9ea68cedca4959d32105ee6a6c3ee1 (patch)
treec4f46929f3d2f345733a43d666a7f6f51e59f6ba /lib
parent5f6966cd9ff9c728d97a8e4075cba738ceca0aeb (diff)
downloadpleroma-9c0040124a9ea68cedca4959d32105ee6a6c3ee1.tar.gz
pleroma-9c0040124a9ea68cedca4959d32105ee6a6c3ee1.zip
Skip remote fetch jobs for unreachable instances
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/workers/remote_fetcher_worker.ex23
1 files changed, 14 insertions, 9 deletions
diff --git a/lib/pleroma/workers/remote_fetcher_worker.ex b/lib/pleroma/workers/remote_fetcher_worker.ex
index ff0286e54..d4fae33df 100644
--- a/lib/pleroma/workers/remote_fetcher_worker.ex
+++ b/lib/pleroma/workers/remote_fetcher_worker.ex
@@ -3,24 +3,29 @@
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Workers.RemoteFetcherWorker do
+ alias Pleroma.Instances
alias Pleroma.Object.Fetcher
use Pleroma.Workers.WorkerHelper, queue: "remote_fetcher"
@impl Oban.Worker
def perform(%Job{args: %{"op" => "fetch_remote", "id" => id} = args}) do
- case Fetcher.fetch_object_from_id(id, depth: args["depth"]) do
- {:ok, _object} ->
- :ok
+ if Instances.reachable?(id) do
+ case Fetcher.fetch_object_from_id(id, depth: args["depth"]) do
+ {:ok, _object} ->
+ :ok
- {:error, reason = "Object fetch has been denied"} ->
- {:cancel, reason}
+ {:error, reason = "Object fetch has been denied"} ->
+ {:cancel, reason}
- {:error, reason = "Object has been deleted"} ->
- {:cancel, reason}
+ {:error, reason = "Object has been deleted"} ->
+ {:cancel, reason}
- _ ->
- :error
+ _ ->
+ :error
+ end
+ else
+ {:cancel, "Unreachable instance"}
end
end