Merge branch 'hotfix/media-proxy-uri' into 'develop'
authorkaniini <nenolod@gmail.com>
Wed, 9 Jan 2019 07:09:39 +0000 (07:09 +0000)
committerkaniini <nenolod@gmail.com>
Wed, 9 Jan 2019 07:09:39 +0000 (07:09 +0000)
user: fix local vs remote determination in remote_or_auth_active?/1

See merge request pleroma/pleroma!640

1  2 
lib/pleroma/user.ex
test/user_test.exs

diff --combined lib/pleroma/user.ex
index 8edf1c73065979dc5fc075ed5e3875715d8e12ff,06049dc626d36bc65b9ec78b0f7cf083e6d11804..7c2849ce233ff2a67cd76a2eb404a3efc7914dba
@@@ -44,20 -44,28 +44,28 @@@ defmodule Pleroma.User d
      timestamps()
    end
  
-   def auth_active?(%User{} = user) do
-     (user.info && !user.info.confirmation_pending) ||
-       !Pleroma.Config.get([:instance, :account_activation_required])
-   end
+   def auth_active?(%User{local: false}), do: true
+   def auth_active?(%User{info: %User.Info{confirmation_pending: false}}), do: true
+   def auth_active?(%User{info: %User.Info{confirmation_pending: true}}),
+     do: !Pleroma.Config.get([:instance, :account_activation_required])
  
-   def remote_or_auth_active?(%User{} = user), do: !user.local || auth_active?(user)
+   def auth_active?(_), do: false
  
-   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)
+   def visible_for?(user, for_user \\ nil)
+   def visible_for?(%User{id: user_id}, %User{id: for_id}) when user_id == for_id, do: true
+   def visible_for?(%User{} = user, for_user) do
+     auth_active?(user) || superuser?(for_user)
    end
  
-   def superuser?(nil), do: false
-   def superuser?(%User{} = user), do: user.info && User.Info.superuser?(user.info)
+   def visible_for?(_, _), do: false
+   def superuser?(%User{local: true, info: %User.Info{is_admin: true}}), do: true
+   def superuser?(%User{local: true, info: %User.Info{is_moderator: true}}), do: true
+   def superuser?(_), do: false
  
    def avatar_url(user) do
      case user.avatar do
      end
    end
  
 +  defp autofollow_users(user) do
 +    candidates = Pleroma.Config.get([:instance, :autofollowed_nicknames])
 +
 +    autofollowed_users =
 +      from(u in User,
 +        where: u.local == true,
 +        where: u.nickname in ^candidates
 +      )
 +      |> Repo.all()
 +
 +    autofollowed_users
 +    |> Enum.reduce({:ok, user}, fn other_user, {:ok, user} ->
 +      follow(user, other_user)
 +    end)
 +  end
 +
    @doc "Inserts provided changeset, performs post-registration actions (confirmation email sending etc.)"
    def register(%Ecto.Changeset{} = changeset) do
      with {:ok, user} <- Repo.insert(changeset),
 -         {:ok, _} = try_send_confirmation_email(user) do
 +         {:ok, _} <- try_send_confirmation_email(user),
 +         {:ok, user} <- autofollow_users(user) do
        {:ok, user}
      end
    end
diff --combined test/user_test.exs
index f8ef2b1dc30a21dadaebded55c6e960374c155bd,542eaaaeb4bf9a01aa3c8fb97858bb96f77377ea..5412525391a508c70651a15742181f328eb45fb9
@@@ -142,23 -142,6 +142,23 @@@ defmodule Pleroma.UserTest d
        email: "email@example.com"
      }
  
 +    test "it autofollows accounts that are set for it" do
 +      user = insert(:user)
 +      remote_user = insert(:user, %{local: false})
 +
 +      Pleroma.Config.put([:instance, :autofollowed_nicknames], [
 +        user.nickname,
 +        remote_user.nickname
 +      ])
 +
 +      cng = User.register_changeset(%User{}, @full_user_data)
 +
 +      {:ok, registered_user} = User.register(cng)
 +
 +      assert User.following?(registered_user, user)
 +      refute User.following?(registered_user, remote_user)
 +    end
 +
      test "it requires an email, name, nickname and password, bio is optional" do
        @full_user_data
        |> Map.keys()
                 |> Map.put(:search_distance, nil)
      end
    end
+   test "auth_active?/1 works correctly" do
+     Pleroma.Config.put([:instance, :account_activation_required], true)
+     local_user = insert(:user, local: true, info: %{confirmation_pending: true})
+     confirmed_user = insert(:user, local: true, info: %{confirmation_pending: false})
+     remote_user = insert(:user, local: false)
+     refute User.auth_active?(local_user)
+     assert User.auth_active?(confirmed_user)
+     assert User.auth_active?(remote_user)
+     Pleroma.Config.put([:instance, :account_activation_required], false)
+   end
+   describe "superuser?/1" do
+     test "returns false for unprivileged users" do
+       user = insert(:user, local: true)
+       refute User.superuser?(user)
+     end
+     test "returns false for remote users" do
+       user = insert(:user, local: false)
+       remote_admin_user = insert(:user, local: false, info: %{is_admin: true})
+       refute User.superuser?(user)
+       refute User.superuser?(remote_admin_user)
+     end
+     test "returns true for local moderators" do
+       user = insert(:user, local: true, info: %{is_moderator: true})
+       assert User.superuser?(user)
+     end
+     test "returns true for local admins" do
+       user = insert(:user, local: true, info: %{is_admin: true})
+       assert User.superuser?(user)
+     end
+   end
+   describe "visible_for?/2" do
+     test "returns true when the account is itself" do
+       user = insert(:user, local: true)
+       assert User.visible_for?(user, user)
+     end
+     test "returns false when the account is unauthenticated and auth is required" do
+       Pleroma.Config.put([:instance, :account_activation_required], true)
+       user = insert(:user, local: true, info: %{confirmation_pending: true})
+       other_user = insert(:user, local: true)
+       refute User.visible_for?(user, other_user)
+       Pleroma.Config.put([:instance, :account_activation_required], false)
+     end
+     test "returns true when the account is unauthenticated and auth is not required" do
+       user = insert(:user, local: true, info: %{confirmation_pending: true})
+       other_user = insert(:user, local: true)
+       assert User.visible_for?(user, other_user)
+     end
+     test "returns true when the account is unauthenticated and being viewed by a privileged account (auth required)" do
+       Pleroma.Config.put([:instance, :account_activation_required], true)
+       user = insert(:user, local: true, info: %{confirmation_pending: true})
+       other_user = insert(:user, local: true, info: %{is_admin: true})
+       assert User.visible_for?(user, other_user)
+       Pleroma.Config.put([:instance, :account_activation_required], false)
+     end
+   end
  end