diff options
author | lain <lain@soykaf.club> | 2019-01-09 11:35:23 +0100 |
---|---|---|
committer | lain <lain@soykaf.club> | 2019-01-09 11:35:23 +0100 |
commit | 26938d65fd5d59e6f50150f4e2bc924429d7733e (patch) | |
tree | 3edadc057dd5df18798149c346e81228147a8317 /lib/pleroma | |
parent | 5c5c8508c203886f32b150e7d8c1f7362a4fde0e (diff) | |
download | pleroma-26938d65fd5d59e6f50150f4e2bc924429d7733e.tar.gz |
Add User mass following function.
Diffstat (limited to 'lib/pleroma')
-rw-r--r-- | lib/pleroma/user.ex | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index 7c2849ce2..916b14350 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -307,6 +307,25 @@ defmodule Pleroma.User do end end + @doc "A mass follow for local users. Ignores blocks and has no side effects" + @spec follow_all(User.t(), list(User.t())) :: {atom(), User.t()} + def follow_all(follower, followeds) do + following = + (follower.following ++ Enum.map(followeds, fn %{follower_address: fa} -> fa end)) + |> Enum.uniq() + + {:ok, follower} = + follower + |> follow_changeset(%{following: following}) + |> update_and_set_cache + + Enum.each(followeds, fn followed -> + update_follower_count(followed) + end) + + {:ok, follower} + end + def follow(%User{} = follower, %User{info: info} = followed) do user_config = Application.get_env(:pleroma, :user) deny_follow_blocked = Keyword.get(user_config, :deny_follow_blocked) |