1 defmodule Pleroma.Object.Fetcher do
3 alias Pleroma.Object.Containment
4 alias Pleroma.Web.ActivityPub.Transmogrifier
5 alias Pleroma.Web.OStatus
9 @httpoison Application.get_env(:pleroma, :httpoison)
11 defp reinject_object(data) do
12 Logger.debug("Reinjecting object #{data["id"]}")
14 with data <- Transmogrifier.fix_object(data),
15 {:ok, object} <- Object.create(data) do
19 Logger.error("Error while processing object: #{inspect(e)}")
25 # This will create a Create activity, which we need internally at the moment.
26 def fetch_object_from_id(id) do
27 if object = Object.get_cached_by_ap_id(id) do
30 Logger.info("Fetching #{id} via AP")
32 with {:ok, data} <- fetch_and_contain_remote_object_from_id(id),
33 nil <- Object.normalize(data, false),
38 "actor" => data["actor"] || data["attributedTo"],
41 :ok <- Containment.contain_origin(id, params),
42 {:ok, activity} <- Transmogrifier.handle_incoming(params),
43 {:object, _data, %Object{} = object} <-
44 {:object, data, Object.normalize(activity, false)} do
47 {:error, {:reject, nil}} ->
50 {:object, data, nil} ->
57 Logger.info("Couldn't get object via AP, trying out OStatus fetching...")
59 case OStatus.fetch_activity_from_url(id) do
60 {:ok, [activity | _]} -> {:ok, Object.normalize(activity, false)}
67 def fetch_object_from_id!(id) do
68 with {:ok, object} <- fetch_object_from_id(id) do
76 def fetch_and_contain_remote_object_from_id(id) do
77 Logger.info("Fetching object #{id} via AP")
79 with true <- String.starts_with?(id, "http"),
80 {:ok, %{body: body, status: code}} when code in 200..299 <-
83 [{:Accept, "application/activity+json"}]
85 {:ok, data} <- Jason.decode(body),
86 :ok <- Containment.contain_origin_from_id(id, data) do