Merge branch 'support/issue_480' into 'develop'
[akkoma] / lib / pleroma / user.ex
index 33f5e43fc4134ce5df3b20096ae50834f8d49d90..41d6e9dc6a3c71449d6c8b7a8645fb96a2b6197b 100644 (file)
@@ -47,6 +47,14 @@ defmodule Pleroma.User do
       !Pleroma.Config.get([:instance, :account_activation_required])
   end
 
+  def remote_or_auth_active?(%User{} = user), do: !user.local || auth_active?(user)
+
+  def visible_for?(%User{} = user, for_user \\ nil) do
+    User.remote_or_auth_active?(user) || (for_user && for_user.id == user.id) ||
+      User.superuser?(for_user)
+  end
+
+  def superuser?(nil), do: false
   def superuser?(%User{} = user), do: user.info && User.Info.superuser?(user.info)
 
   def avatar_url(user) do