Fetch user on externalprofile if we don't know him
authorRoger Braun <roger@rogerbraun.net>
Fri, 12 May 2017 16:50:47 +0000 (18:50 +0200)
committerRoger Braun <roger@rogerbraun.net>
Fri, 12 May 2017 16:50:47 +0000 (18:50 +0200)
lib/pleroma/web/twitter_api/twitter_api.ex

index d048d07c32aef0dadaf3ac992ca8afa410c45041..6503d72224eae33baa419850034dc0c6244b944c 100644 (file)
@@ -2,6 +2,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
   alias Pleroma.{User, Activity, Repo, Object}
   alias Pleroma.Web.ActivityPub.ActivityPub
   alias Pleroma.Web.TwitterAPI.Representers.{ActivityRepresenter, UserRepresenter}
+  alias Pleroma.Web.OStatus
 
   import Ecto.Query
 
@@ -352,10 +353,10 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
   end
 
   def get_external_profile(for_user, uri) do
-    with %User{} = user <- User.get_cached_by_ap_id(uri) do
+    with {:ok, %User{} = user} <- OStatus.find_or_make_user(uri) do
       {:ok, UserRepresenter.to_map(user, %{for: for_user})}
     else _e ->
-      {:error, "Couldn't find user"}
+        {:error, "Couldn't find user"}
     end
   end
 end