else
with {_, %Activity{} = activity} <- {:activity, Activity.get_by_id_with_object(id)},
{_, true} <- {:public?, Visibility.is_public?(activity)},
- %User{} = user <- User.get_cached_by_ap_id(activity.data["actor"]) do
+ %User{} = user <- User.get_cached_by_ap_id(activity.data["actor"]) do
cond do
format == "html" && activity.data["type"] == "Create" ->
%Object{} = object = Object.normalize(activity)
alias Pleroma.Web.ActivityPub.Visibility
alias Pleroma.Web.Router.Helpers
- def prepare_activity(%User{} = user, %Object{} = object, activity_id) do
+ def prepare_activity(%User{} = user, %Activity{} = activity) do
+ object = Object.normalize(activity.data["object"])
+
%{}
|> set_user(user)
|> set_object(object)
|> set_title(object)
|> set_content(object)
- |> set_link(activity_id)
+ |> set_link(activity.id)
|> set_published(object)
|> set_attachments(object)
end
- def prepare_activity(%User{} = user, %Activity{} = activity),
- do: prepare_activity(user, Object.normalize(activity.data["object"]), activity.id)
-
defp set_user(data, %User{} = user), do: Map.put(data, :user, user)
defp set_object(data, %Object{} = object), do: Map.put(data, :object, object)
def represent(activity_id) do
with %Activity{data: %{"type" => "Create"}} = activity <- Activity.get_by_id(activity_id),
true <- Visibility.is_public?(activity),
- %Object{} = object <- Object.normalize(activity.data["object"]),
- %User{} = user <- User.get_or_fetch(activity.data["actor"]),
- data <- prepare_activity(user, object, activity_id) do
- {:ok, data}
+ {:ok, %User{} = user} <- User.get_or_fetch(activity.data["actor"]) do
+ {:ok, prepare_activity(user, activity)}
else
e ->
{:error, e}