Add follower / friend fetching to user.
authorRoger Braun <roger@rogerbraun.net>
Thu, 20 Jul 2017 17:37:41 +0000 (19:37 +0200)
committerRoger Braun <roger@rogerbraun.net>
Thu, 20 Jul 2017 17:37:41 +0000 (19:37 +0200)
lib/pleroma/user.ex
test/user_test.exs

index af0e569a49f2280f51df92ac8d2899146eb4765f..d5befa67bb9ee738bcf8adc56eda4ef4fe5286fe 100644 (file)
@@ -186,4 +186,21 @@ defmodule Pleroma.User do
       end
     end
   end
+
+  # TODO: these queries could be more efficient if the type in postgresql wasn't map, but array.
+  def get_followers(%User{id: id, follower_address: follower_address}) do
+    q = from u in User,
+      where: fragment("? @> ?", u.following, ^follower_address ),
+      where: u.id != ^id
+
+    {:ok, Repo.all(q)}
+  end
+
+  def get_friends(%User{id: id, following: following}) do
+    q = from u in User,
+      where: u.follower_address in ^following,
+      where: u.id != ^id
+
+    {:ok, Repo.all(q)}
+  end
 end
index 0f42e9b513495c8047935d14a90ed7d6d82b3640..81827afa318a11e43d88dd6d8a8bd73f8e25b92b 100644 (file)
@@ -197,5 +197,35 @@ defmodule Pleroma.UserTest do
       end)
     end
   end
+
+  describe "followers and friends" do
+    test "gets all followers for a given user" do
+      user = insert(:user)
+      follower_one = insert(:user)
+      follower_two = insert(:user)
+      not_follower = insert(:user)
+
+      {:ok, follower_one} = User.follow(follower_one, user)
+      {:ok, follower_two} = User.follow(follower_two, user)
+
+      {:ok, res} = User.get_followers(user)
+
+      assert res == [follower_one, follower_two]
+    end
+
+    test "gets all friends (followed users) for a given user" do
+      user = insert(:user)
+      followed_one = insert(:user)
+      followed_two = insert(:user)
+      not_followed = insert(:user)
+
+      {:ok, user} = User.follow(user, followed_one)
+      {:ok, user} = User.follow(user, followed_two)
+
+      {:ok, res} = User.get_friends(user)
+
+      assert res == [followed_one, followed_two]
+    end
+  end
 end