1 defmodule Pleroma.Object.Fetcher do
4 alias Pleroma.Object.Containment
5 alias Pleroma.Web.ActivityPub.Transmogrifier
6 alias Pleroma.Web.OStatus
10 defp reinject_object(data) do
11 Logger.debug("Reinjecting object #{data["id"]}")
13 with data <- Transmogrifier.fix_object(data),
14 {:ok, object} <- Object.create(data) do
18 Logger.error("Error while processing object: #{inspect(e)}")
24 # This will create a Create activity, which we need internally at the moment.
25 def fetch_object_from_id(id) do
26 if object = Object.get_cached_by_ap_id(id) do
29 Logger.info("Fetching #{id} via AP")
31 with {:ok, data} <- fetch_and_contain_remote_object_from_id(id),
32 nil <- Object.normalize(data, false),
37 "actor" => data["actor"] || data["attributedTo"],
40 :ok <- Containment.contain_origin(id, params),
41 {:ok, activity} <- Transmogrifier.handle_incoming(params),
42 {:object, _data, %Object{} = object} <-
43 {:object, data, Object.normalize(activity, false)} do
46 {:error, {:reject, nil}} ->
49 {:object, data, nil} ->
56 Logger.info("Couldn't get object via AP, trying out OStatus fetching...")
58 case OStatus.fetch_activity_from_url(id) do
59 {:ok, [activity | _]} -> {:ok, Object.normalize(activity, false)}
66 def fetch_object_from_id!(id) do
67 with {:ok, object} <- fetch_object_from_id(id) do
75 def fetch_and_contain_remote_object_from_id(id) do
76 Logger.info("Fetching object #{id} via AP")
78 with true <- String.starts_with?(id, "http"),
79 {:ok, %{body: body, status: code}} when code in 200..299 <-
82 [{:Accept, "application/activity+json"}]
84 {:ok, data} <- Jason.decode(body),
85 :ok <- Containment.contain_origin_from_id(id, data) do
88 {:ok, %{status: code}} when code in [404, 410] ->
89 {:error, "Object has been deleted"}