From 1d8950798c8aef2cee4458c68d34a72da630ec41 Mon Sep 17 00:00:00 2001
From: Phil Hagelberg <phil@hagelb.org>
Date: Sun, 27 Oct 2019 19:02:19 -0700
Subject: [PATCH] Fix activity_representer to work with User.get_or_fetch
 returning tuple.

---
 lib/pleroma/web/ostatus/ostatus_controller.ex     |  2 +-
 lib/pleroma/web/static_fe/activity_representer.ex | 15 ++++++---------
 2 files changed, 7 insertions(+), 10 deletions(-)

diff --git a/lib/pleroma/web/ostatus/ostatus_controller.ex b/lib/pleroma/web/ostatus/ostatus_controller.ex
index 76a244d0f..ab5fdbc78 100644
--- a/lib/pleroma/web/ostatus/ostatus_controller.ex
+++ b/lib/pleroma/web/ostatus/ostatus_controller.ex
@@ -81,7 +81,7 @@ defmodule Pleroma.Web.OStatus.OStatusController do
     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)
diff --git a/lib/pleroma/web/static_fe/activity_representer.ex b/lib/pleroma/web/static_fe/activity_representer.ex
index e383b8415..9bee732d5 100644
--- a/lib/pleroma/web/static_fe/activity_representer.ex
+++ b/lib/pleroma/web/static_fe/activity_representer.ex
@@ -9,20 +9,19 @@ defmodule Pleroma.Web.StaticFE.ActivityRepresenter do
   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)
@@ -52,10 +51,8 @@ defmodule Pleroma.Web.StaticFE.ActivityRepresenter do
   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}
-- 
2.49.0