# Pleroma: A lightweight social networking server # Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Web.ActivityPub.VisibilityTest do use Pleroma.DataCase alias Pleroma.Activity 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) {:ok, following} = 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, 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 } end test "is_direct?", %{ public: public, private: private, direct: direct, unlisted: unlisted, list: list } 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) end test "is_public?", %{ public: public, private: private, direct: direct, unlisted: unlisted, list: list } do refute Visibility.is_public?(direct) assert Visibility.is_public?(public) refute Visibility.is_public?(private) assert Visibility.is_public?(unlisted) refute Visibility.is_public?(list) end test "is_private?", %{ public: public, private: private, direct: direct, unlisted: unlisted, list: list } 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) end test "is_list?", %{ public: public, private: private, direct: direct, unlisted: unlisted, list: list } 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) end test "visible_for_user?", %{ public: public, private: private, direct: direct, unlisted: unlisted, user: user, mentioned: mentioned, following: following, unrelated: unrelated, list: list } 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) # 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) # 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) Cachex.clear(:user_cache) 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, following: [author.ap_id]) 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