Add function to fetch users from fqn.
authorRoger Braun <roger@rogerbraun.net>
Sun, 30 Apr 2017 16:48:48 +0000 (18:48 +0200)
committerRoger Braun <roger@rogerbraun.net>
Sun, 30 Apr 2017 16:48:48 +0000 (18:48 +0200)
lib/pleroma/user.ex
test/user_test.exs

index 58f89a915487ee8408a9b59ad0be6834eb6fea5f..c264d7e90994560824d88c7557fc43d7bbbe3eef 100644 (file)
@@ -3,6 +3,7 @@ defmodule Pleroma.User do
   import Ecto.Changeset
   import Ecto.Query
   alias Pleroma.{Repo, User, Activity, Object}
+  alias Pleroma.Web.OStatus
 
   schema "users" do
     field :bio, :string
@@ -131,4 +132,15 @@ defmodule Pleroma.User do
     key = "user_info:#{user.id}"
     Cachex.get!(:user_cache, key, fallback: fn(_) -> user_info(user) end)
   end
+
+  def get_or_fetch_by_nickname(nickname) do
+    with %User{} = user <- get_by_nickname(nickname)  do
+      user
+    else _e ->
+      with {:ok, user} <- OStatus.make_user(nickname) do
+        user
+      else _e -> nil
+      end
+    end
+  end
 end
index d711adb9db3ae1c1d9246675ef1001b16d89d052..6684aa434ac3516488dd59b3b1870b27f9648033 100644 (file)
@@ -86,4 +86,24 @@ defmodule Pleroma.UserTest do
       assert changeset.changes[:following] == [User.ap_followers(%User{nickname: @full_user_data.nickname})]
     end
   end
+
+  describe "fetching a user from nickname or trying to build one" do
+    test "gets an existing user" do
+      user = insert(:user)
+      fetched_user = User.get_or_fetch_by_nickname(user.nickname)
+
+      assert user == fetched_user
+    end
+
+    test "fetches an external user via ostatus if no user exists" do
+      fetched_user = User.get_or_fetch_by_nickname("shp@social.heldscal.la")
+      assert fetched_user.nickname == "shp@social.heldscal.la"
+    end
+
+    test "returns nil if no user could be fetched" do
+      fetched_user = User.get_or_fetch_by_nickname("nonexistant@social.heldscal.la")
+      assert fetched_user == nil
+    end
+  end
 end
+