# Pleroma: A lightweight social networking server # Copyright © 2017-2021 Pleroma Authors # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Workers.ReceiverWorker do require Logger alias Pleroma.Web.Federator use Pleroma.Workers.WorkerHelper, queue: "federator_incoming" @impl Oban.Worker def perform(%Job{args: %{"op" => "incoming_ap_doc", "params" => params}}) do with {:ok, res} <- Federator.perform(:incoming_ap_doc, params) do {:ok, res} else {:error, :origin_containment_failed} -> {:discard, :origin_containment_failed} {:error, {:reject, reason}} -> {:discard, reason} {:error, :already_present} -> {:discard, :already_present} # invalid data or e.g. deleting an object we don't know about anyway {:error, {:error, {:validate, issue}}} -> Logger.info("Received invalid AP document: #{inspect(issue)}") {:discard, :invalid} # rarer, but sometimes there’s an additional :error in front {:error, {:error, {:error, {:validate, issue}}}} -> Logger.info("Received invalid AP document: (3e) #{inspect(issue)}") {:discard, :invalid} {:error, _} = e -> Logger.error("Unexpected AP doc error: #{inspect(e)} from #{inspect(params)}") e e -> Logger.error("Unexpected AP doc error: (raw) #{inspect(e)} from #{inspect(params)}") {:error, e} end end end