mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-03 05:48:42 +00:00
RemoteReportPolicy: Fix third-party report detection
This commit is contained in:
parent
55612cb8ee
commit
48af6850fc
2 changed files with 15 additions and 2 deletions
|
@ -47,7 +47,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.RemoteReportPolicy do
|
||||||
end
|
end
|
||||||
|
|
||||||
with true <- Config.get([:mrf_remote_report, :reject_third_party]),
|
with true <- Config.get([:mrf_remote_report, :reject_third_party]),
|
||||||
String.starts_with?(to, Pleroma.Web.Endpoint.url()) do
|
false <- String.starts_with?(to, Pleroma.Web.Endpoint.url()) do
|
||||||
{:reject, "[RemoteReportPolicy] Third-party: #{to}"}
|
{:reject, "[RemoteReportPolicy] Third-party: #{to}"}
|
||||||
else
|
else
|
||||||
_ -> {:ok, object}
|
_ -> {:ok, object}
|
||||||
|
|
|
@ -46,7 +46,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.RemoteReportPolicyTest do
|
||||||
assert {:ok, _} = RemoteReportPolicy.filter(activity)
|
assert {:ok, _} = RemoteReportPolicy.filter(activity)
|
||||||
end
|
end
|
||||||
|
|
||||||
test "rejects report on third-party if `reject_third_party: true`" do
|
test "rejects report on third party if `reject_third_party: true`" do
|
||||||
clear_config([:mrf_remote_report, :reject_third_party], true)
|
clear_config([:mrf_remote_report, :reject_third_party], true)
|
||||||
clear_config([:mrf_remote_report, :reject_empty_message], false)
|
clear_config([:mrf_remote_report, :reject_empty_message], false)
|
||||||
|
|
||||||
|
@ -59,6 +59,19 @@ defmodule Pleroma.Web.ActivityPub.MRF.RemoteReportPolicyTest do
|
||||||
assert {:reject, _} = RemoteReportPolicy.filter(activity)
|
assert {:reject, _} = RemoteReportPolicy.filter(activity)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "preserves report on first party if `reject_third_party: true`" do
|
||||||
|
clear_config([:mrf_remote_report, :reject_third_party], true)
|
||||||
|
clear_config([:mrf_remote_report, :reject_empty_message], false)
|
||||||
|
|
||||||
|
activity = %{
|
||||||
|
"type" => "Flag",
|
||||||
|
"actor" => "https://mastodon.social/users/Gargron",
|
||||||
|
"object" => ["http://localhost:4001/actor"]
|
||||||
|
}
|
||||||
|
|
||||||
|
assert {:ok, _} = RemoteReportPolicy.filter(activity)
|
||||||
|
end
|
||||||
|
|
||||||
test "preserves report on third party if `reject_third_party: false`" do
|
test "preserves report on third party if `reject_third_party: false`" do
|
||||||
clear_config([:mrf_remote_report, :reject_third_party], false)
|
clear_config([:mrf_remote_report, :reject_third_party], false)
|
||||||
clear_config([:mrf_remote_report, :reject_empty_message], false)
|
clear_config([:mrf_remote_report, :reject_empty_message], false)
|
||||||
|
|
Loading…
Reference in a new issue