326 lines
		
	
	
	
		
			9.7 KiB
		
	
	
	
		
			Elixir
		
	
	
	
	
	
			
		
		
	
	
			326 lines
		
	
	
	
		
			9.7 KiB
		
	
	
	
		
			Elixir
		
	
	
	
	
	
# Pleroma: A lightweight social networking server
 | 
						|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
 | 
						|
# SPDX-License-Identifier: AGPL-3.0-only
 | 
						|
 | 
						|
defmodule Pleroma.Web.ActivityPub.VisibilityTest do
 | 
						|
  use Pleroma.DataCase, async: true
 | 
						|
 | 
						|
  alias Pleroma.Activity
 | 
						|
  alias Pleroma.Object
 | 
						|
  alias Pleroma.Web.ActivityPub.Visibility
 | 
						|
  alias Pleroma.Web.CommonAPI
 | 
						|
  import Pleroma.Factory
 | 
						|
 | 
						|
  setup do
 | 
						|
    user = insert(:user)
 | 
						|
    mentioned = insert(:user)
 | 
						|
    following = insert(:user)
 | 
						|
    unrelated = insert(:user)
 | 
						|
    remote = insert(:user, local: false)
 | 
						|
    {:ok, following, user} = Pleroma.User.follow(following, user)
 | 
						|
    {:ok, list} = Pleroma.List.create("foo", user)
 | 
						|
 | 
						|
    Pleroma.List.follow(list, unrelated)
 | 
						|
 | 
						|
    {:ok, public} =
 | 
						|
      CommonAPI.post(user, %{status: "@#{mentioned.nickname}", visibility: "public"})
 | 
						|
 | 
						|
    {:ok, private} =
 | 
						|
      CommonAPI.post(user, %{status: "@#{mentioned.nickname}", visibility: "private"})
 | 
						|
 | 
						|
    {:ok, direct} =
 | 
						|
      CommonAPI.post(user, %{status: "@#{mentioned.nickname}", visibility: "direct"})
 | 
						|
 | 
						|
    {:ok, unlisted} =
 | 
						|
      CommonAPI.post(user, %{status: "@#{mentioned.nickname}", visibility: "unlisted"})
 | 
						|
 | 
						|
    {:ok, local} = CommonAPI.post(user, %{status: "@#{mentioned.nickname}", visibility: "local"})
 | 
						|
 | 
						|
    {:ok, list} =
 | 
						|
      CommonAPI.post(user, %{
 | 
						|
        status: "@#{mentioned.nickname}",
 | 
						|
        visibility: "list:#{list.id}"
 | 
						|
      })
 | 
						|
 | 
						|
    %{
 | 
						|
      public: public,
 | 
						|
      private: private,
 | 
						|
      direct: direct,
 | 
						|
      unlisted: unlisted,
 | 
						|
      user: user,
 | 
						|
      mentioned: mentioned,
 | 
						|
      following: following,
 | 
						|
      unrelated: unrelated,
 | 
						|
      list: list,
 | 
						|
      local: local,
 | 
						|
      remote: remote
 | 
						|
    }
 | 
						|
  end
 | 
						|
 | 
						|
  test "is_direct?", %{
 | 
						|
    public: public,
 | 
						|
    private: private,
 | 
						|
    direct: direct,
 | 
						|
    unlisted: unlisted,
 | 
						|
    list: list,
 | 
						|
    local: local
 | 
						|
  } do
 | 
						|
    assert Visibility.is_direct?(direct)
 | 
						|
    refute Visibility.is_direct?(public)
 | 
						|
    refute Visibility.is_direct?(private)
 | 
						|
    refute Visibility.is_direct?(unlisted)
 | 
						|
    assert Visibility.is_direct?(list)
 | 
						|
    refute Visibility.is_direct?(local)
 | 
						|
  end
 | 
						|
 | 
						|
  test "is_public?", %{
 | 
						|
    public: public,
 | 
						|
    private: private,
 | 
						|
    direct: direct,
 | 
						|
    unlisted: unlisted,
 | 
						|
    local: local,
 | 
						|
    list: list
 | 
						|
  } do
 | 
						|
    refute Visibility.is_public?(direct)
 | 
						|
    assert Visibility.is_public?(public)
 | 
						|
    refute Visibility.is_public?(private)
 | 
						|
    assert Visibility.is_public?(unlisted)
 | 
						|
    assert Visibility.is_public?(local)
 | 
						|
    refute Visibility.is_public?(list)
 | 
						|
  end
 | 
						|
 | 
						|
  test "is_private?", %{
 | 
						|
    public: public,
 | 
						|
    private: private,
 | 
						|
    direct: direct,
 | 
						|
    unlisted: unlisted,
 | 
						|
    list: list,
 | 
						|
    local: local
 | 
						|
  } do
 | 
						|
    refute Visibility.is_private?(direct)
 | 
						|
    refute Visibility.is_private?(public)
 | 
						|
    assert Visibility.is_private?(private)
 | 
						|
    refute Visibility.is_private?(unlisted)
 | 
						|
    refute Visibility.is_private?(list)
 | 
						|
    refute Visibility.is_private?(local)
 | 
						|
  end
 | 
						|
 | 
						|
  test "is_list?", %{
 | 
						|
    public: public,
 | 
						|
    private: private,
 | 
						|
    direct: direct,
 | 
						|
    unlisted: unlisted,
 | 
						|
    list: list,
 | 
						|
    local: local
 | 
						|
  } do
 | 
						|
    refute Visibility.is_list?(direct)
 | 
						|
    refute Visibility.is_list?(public)
 | 
						|
    refute Visibility.is_list?(private)
 | 
						|
    refute Visibility.is_list?(unlisted)
 | 
						|
    assert Visibility.is_list?(list)
 | 
						|
    refute Visibility.is_list?(local)
 | 
						|
  end
 | 
						|
 | 
						|
  test "visible_for_user? Activity", %{
 | 
						|
    public: public,
 | 
						|
    private: private,
 | 
						|
    direct: direct,
 | 
						|
    unlisted: unlisted,
 | 
						|
    user: user,
 | 
						|
    mentioned: mentioned,
 | 
						|
    following: following,
 | 
						|
    unrelated: unrelated,
 | 
						|
    list: list,
 | 
						|
    local: local,
 | 
						|
    remote: remote
 | 
						|
  } do
 | 
						|
    # All visible to author
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, user)
 | 
						|
    assert Visibility.visible_for_user?(private, user)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, user)
 | 
						|
    assert Visibility.visible_for_user?(direct, user)
 | 
						|
    assert Visibility.visible_for_user?(list, user)
 | 
						|
    assert Visibility.visible_for_user?(local, user)
 | 
						|
 | 
						|
    # All visible to a mentioned user
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(private, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(direct, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(list, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(local, mentioned)
 | 
						|
 | 
						|
    # DM not visible for just follower
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, following)
 | 
						|
    assert Visibility.visible_for_user?(private, following)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, following)
 | 
						|
    refute Visibility.visible_for_user?(direct, following)
 | 
						|
    refute Visibility.visible_for_user?(list, following)
 | 
						|
    assert Visibility.visible_for_user?(local, following)
 | 
						|
 | 
						|
    # Public and unlisted visible for unrelated user
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, unrelated)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, unrelated)
 | 
						|
    refute Visibility.visible_for_user?(private, unrelated)
 | 
						|
    refute Visibility.visible_for_user?(direct, unrelated)
 | 
						|
    assert Visibility.visible_for_user?(local, unrelated)
 | 
						|
 | 
						|
    # Public and unlisted visible for unauthenticated
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, nil)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, nil)
 | 
						|
    refute Visibility.visible_for_user?(private, nil)
 | 
						|
    refute Visibility.visible_for_user?(direct, nil)
 | 
						|
    refute Visibility.visible_for_user?(local, nil)
 | 
						|
 | 
						|
    # Visible for a list member
 | 
						|
    assert Visibility.visible_for_user?(list, unrelated)
 | 
						|
 | 
						|
    # Local not visible to remote user
 | 
						|
    refute Visibility.visible_for_user?(local, remote)
 | 
						|
  end
 | 
						|
 | 
						|
  test "visible_for_user? Object", %{
 | 
						|
    public: public,
 | 
						|
    private: private,
 | 
						|
    direct: direct,
 | 
						|
    unlisted: unlisted,
 | 
						|
    user: user,
 | 
						|
    mentioned: mentioned,
 | 
						|
    following: following,
 | 
						|
    unrelated: unrelated,
 | 
						|
    list: list,
 | 
						|
    local: local,
 | 
						|
    remote: remote
 | 
						|
  } do
 | 
						|
    public = Object.normalize(public)
 | 
						|
    private = Object.normalize(private)
 | 
						|
    unlisted = Object.normalize(unlisted)
 | 
						|
    direct = Object.normalize(direct)
 | 
						|
    list = Object.normalize(list)
 | 
						|
    local = Object.normalize(local)
 | 
						|
 | 
						|
    # All visible to author
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, user)
 | 
						|
    assert Visibility.visible_for_user?(private, user)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, user)
 | 
						|
    assert Visibility.visible_for_user?(direct, user)
 | 
						|
    assert Visibility.visible_for_user?(list, user)
 | 
						|
 | 
						|
    # All visible to a mentioned user
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(private, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(direct, mentioned)
 | 
						|
    assert Visibility.visible_for_user?(list, mentioned)
 | 
						|
 | 
						|
    # DM not visible for just follower
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, following)
 | 
						|
    assert Visibility.visible_for_user?(private, following)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, following)
 | 
						|
    refute Visibility.visible_for_user?(direct, following)
 | 
						|
    refute Visibility.visible_for_user?(list, following)
 | 
						|
 | 
						|
    # Public and unlisted visible for unrelated user
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, unrelated)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, unrelated)
 | 
						|
    refute Visibility.visible_for_user?(private, unrelated)
 | 
						|
    refute Visibility.visible_for_user?(direct, unrelated)
 | 
						|
 | 
						|
    # Public and unlisted visible for unauthenticated
 | 
						|
 | 
						|
    assert Visibility.visible_for_user?(public, nil)
 | 
						|
    assert Visibility.visible_for_user?(unlisted, nil)
 | 
						|
    refute Visibility.visible_for_user?(private, nil)
 | 
						|
    refute Visibility.visible_for_user?(direct, nil)
 | 
						|
    refute Visibility.visible_for_user?(local, nil)
 | 
						|
 | 
						|
    # Local posts to remote
 | 
						|
    refute Visibility.visible_for_user?(local, remote)
 | 
						|
    # Visible for a list member
 | 
						|
    # assert Visibility.visible_for_user?(list, unrelated)
 | 
						|
  end
 | 
						|
 | 
						|
  test "doesn't die when the user doesn't exist",
 | 
						|
       %{
 | 
						|
         direct: direct,
 | 
						|
         user: user
 | 
						|
       } do
 | 
						|
    Repo.delete(user)
 | 
						|
    Pleroma.User.invalidate_cache(user)
 | 
						|
    refute Visibility.is_private?(direct)
 | 
						|
  end
 | 
						|
 | 
						|
  test "get_visibility", %{
 | 
						|
    public: public,
 | 
						|
    private: private,
 | 
						|
    direct: direct,
 | 
						|
    unlisted: unlisted,
 | 
						|
    list: list
 | 
						|
  } do
 | 
						|
    assert Visibility.get_visibility(public) == "public"
 | 
						|
    assert Visibility.get_visibility(private) == "private"
 | 
						|
    assert Visibility.get_visibility(direct) == "direct"
 | 
						|
    assert Visibility.get_visibility(unlisted) == "unlisted"
 | 
						|
    assert Visibility.get_visibility(list) == "list"
 | 
						|
  end
 | 
						|
 | 
						|
  test "get_visibility with directMessage flag" do
 | 
						|
    assert Visibility.get_visibility(%{data: %{"directMessage" => true}}) == "direct"
 | 
						|
  end
 | 
						|
 | 
						|
  test "get_visibility with listMessage flag" do
 | 
						|
    assert Visibility.get_visibility(%{data: %{"listMessage" => ""}}) == "list"
 | 
						|
  end
 | 
						|
 | 
						|
  describe "entire_thread_visible_for_user?/2" do
 | 
						|
    test "returns false if not found activity", %{user: user} do
 | 
						|
      refute Visibility.entire_thread_visible_for_user?(%Activity{}, user)
 | 
						|
    end
 | 
						|
 | 
						|
    test "returns true if activity hasn't 'Create' type", %{user: user} do
 | 
						|
      activity = insert(:like_activity)
 | 
						|
      assert Visibility.entire_thread_visible_for_user?(activity, user)
 | 
						|
    end
 | 
						|
 | 
						|
    test "returns false when invalid recipients", %{user: user} do
 | 
						|
      author = insert(:user)
 | 
						|
 | 
						|
      activity =
 | 
						|
        insert(:note_activity,
 | 
						|
          note:
 | 
						|
            insert(:note,
 | 
						|
              user: author,
 | 
						|
              data: %{"to" => ["test-user"]}
 | 
						|
            )
 | 
						|
        )
 | 
						|
 | 
						|
      refute Visibility.entire_thread_visible_for_user?(activity, user)
 | 
						|
    end
 | 
						|
 | 
						|
    test "returns true if user following to author" do
 | 
						|
      author = insert(:user)
 | 
						|
      user = insert(:user)
 | 
						|
      Pleroma.User.follow(user, author)
 | 
						|
 | 
						|
      activity =
 | 
						|
        insert(:note_activity,
 | 
						|
          note:
 | 
						|
            insert(:note,
 | 
						|
              user: author,
 | 
						|
              data: %{"to" => [user.ap_id]}
 | 
						|
            )
 | 
						|
        )
 | 
						|
 | 
						|
      assert Visibility.entire_thread_visible_for_user?(activity, user)
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |