Merge 2023.05 stable #8

Merged
fedward merged 29 commits from AkkomaGang/akkoma:stable into stable 2023-05-30 19:19:23 +00:00
2 changed files with 29 additions and 10 deletions
Showing only changes of commit 8c208f751d - Show all commits

View file

@ -2,7 +2,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.DirectMessageDisabledPolicy do
@behaviour Pleroma.Web.ActivityPub.MRF.Policy @behaviour Pleroma.Web.ActivityPub.MRF.Policy
alias Pleroma.User alias Pleroma.User
alias Pleroma.Web.ActivityPub.Visibility require Pleroma.Constants
@moduledoc """ @moduledoc """
Removes entries from the "To" field from direct messages if the user has requested to not Removes entries from the "To" field from direct messages if the user has requested to not
@ -13,15 +13,19 @@ defmodule Pleroma.Web.ActivityPub.MRF.DirectMessageDisabledPolicy do
def filter( def filter(
%{ %{
"type" => "Create", "type" => "Create",
"actor" => actor "actor" => actor,
"object" => %{
"type" => "Note"
}
} = activity } = activity
) do ) do
with true <- Visibility.is_direct?(%{data: activity}), with recipients <- Map.get(activity, "to", []),
recipients <- Map.get(activity, "to"), cc <- Map.get(activity, "cc", []),
true <- is_direct?(recipients, cc),
sender <- User.get_cached_by_ap_id(actor) do sender <- User.get_cached_by_ap_id(actor) do
new_to = new_to =
Enum.filter(recipients, fn recv -> Enum.filter(recipients, fn recv ->
should_filter?(sender, recv) should_include?(sender, recv)
end) end)
{:ok, {:ok,
@ -40,11 +44,11 @@ def filter(object), do: {:ok, object}
@impl true @impl true
def describe, do: {:ok, %{}} def describe, do: {:ok, %{}}
defp should_filter?(sender, receiver_ap_id) do defp should_include?(sender, receiver_ap_id) do
with %User{local: true} = receiver <- User.get_cached_by_ap_id(receiver_ap_id) do with %User{local: true} = receiver <- User.get_cached_by_ap_id(receiver_ap_id) do
User.accepts_direct_messages?(receiver, sender) User.accepts_direct_messages?(receiver, sender)
else else
_ -> false _ -> true
end end
end end
@ -53,4 +57,9 @@ defp maybe_replace_object_to(%{"object" => %{"to" => _}} = activity, to) do
end end
defp maybe_replace_object_to(other, _), do: other defp maybe_replace_object_to(other, _), do: other
defp is_direct?(to, cc) do
!(Enum.member?(to, Pleroma.Constants.as_public()) ||
Enum.member?(cc, Pleroma.Constants.as_public()))
end
end end

View file

@ -16,10 +16,15 @@ test "when the user denies the direct message" do
"actor" => sender.ap_id, "actor" => sender.ap_id,
"to" => [recipient.ap_id], "to" => [recipient.ap_id],
"cc" => [], "cc" => [],
"type" => "Create" "type" => "Create",
"object" => %{
"type" => "Note",
"to" => [recipient.ap_id]
}
} }
assert {:ok, %{"to" => []}} = DirectMessageDisabledPolicy.filter(message) assert {:ok, %{"to" => [], "object" => %{"to" => []}}} =
DirectMessageDisabledPolicy.filter(message)
end end
test "when the user does not deny the direct message" do test "when the user does not deny the direct message" do
@ -32,11 +37,16 @@ test "when the user does not deny the direct message" do
"actor" => sender.ap_id, "actor" => sender.ap_id,
"to" => [recipient.ap_id], "to" => [recipient.ap_id],
"cc" => [], "cc" => [],
"type" => "Create" "type" => "Create",
"object" => %{
"type" => "Note",
"to" => [recipient.ap_id]
}
} }
assert {:ok, message} = DirectMessageDisabledPolicy.filter(message) assert {:ok, message} = DirectMessageDisabledPolicy.filter(message)
assert message["to"] == [recipient.ap_id] assert message["to"] == [recipient.ap_id]
assert message["object"]["to"] == [recipient.ap_id]
end end
end end
end end