treat rejections in MRF as a reject in federator (#155)
[akkoma] / lib / pleroma / workers / receiver_worker.ex
index 69125dcd07156da044e750fb96aa09e50e551d4f..b8905deb59fefe8425bb7fe0149fd8f768886db5 100644 (file)
@@ -9,6 +9,12 @@ defmodule Pleroma.Workers.ReceiverWorker do
 
   @impl Oban.Worker
   def perform(%Job{args: %{"op" => "incoming_ap_doc", "params" => params}}) do
-    Federator.perform(:incoming_ap_doc, params)
+    with {:ok, res} <- Federator.perform(:incoming_ap_doc, params) do
+      {:ok, res}
+    else
+      {:error, :origin_containment_failed} -> {:cancel, :origin_containment_failed}
+      {:error, {:reject, reason}} -> {:cancel, reason}
+      e -> e
+    end
   end
 end