aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web
diff options
context:
space:
mode:
Diffstat (limited to 'lib/pleroma/web')
-rw-r--r--lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex31
1 files changed, 19 insertions, 12 deletions
diff --git a/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex b/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex
index d95424493..cd9f9b1c4 100644
--- a/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex
+++ b/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex
@@ -6,27 +6,34 @@ defmodule Pleroma.Web.ActivityPub.MRF.HellthreadPolicy do
alias Pleroma.User
@behaviour Pleroma.Web.ActivityPub.MRF
+ defp delist_message(object) do
+ follower_collection = User.get_by_ap_id(object["actor"].follower_address)
+
+ object
+ |> Kernel.update_in(["to"], [follower_collection])
+ |> Kernel.update_in(["cc"], ["https://www.w3.org/ns/activitystreams#Public"])
+ end
+
@impl true
def filter(%{"type" => "Create"} = object) do
delist_threshold = Pleroma.Config.get([:mrf_hellthread, :delist_threshold])
- reject_threshold = Pleroma.Config.get([:mrf_hellthread, :reject_threshold])
+
+ reject_threshold =
+ Pleroma.Config.get(
+ [:mrf_hellthread, :reject_threshold],
+ Pleroma.Config.get([:mrf_hellthread, :threshold])
+ )
+
recipients = (object["to"] || []) ++ (object["cc"] || [])
cond do
- length(recipients) > reject_threshold and reject_threshold != 0 ->
+ length(recipients) > reject_threshold and reject_threshold > 0 ->
{:reject, nil}
- length(recipients) > delist_threshold and delist_threshold != 0 ->
+ length(recipients) > delist_threshold and delist_threshold > 0 ->
if Enum.member?(object["to"], "https://www.w3.org/ns/activitystreams#Public") or
- Enum.member?(object["cc"], "https://www.w3.org/ns/activitystreams#Public") do
- follower_collection = User.get_by_ap_id(object["actor"].follower_address)
-
- object
- |> Kernel.update_in(["object", "to"], [follower_collection])
- |> Kernel.update_in(["object", "cc"], ["https://www.w3.org/ns/activitystreams#Public"])
- |> Kernel.update_in(["to"], [follower_collection])
- |> Kernel.update_in(["cc"], ["https://www.w3.org/ns/activitystreams#Public"])
-
+ Enum.member?(object["to"], "https://www.w3.org/ns/activitystreams#Public") do
+ delist_message(object)
{:ok, object}
else
{:ok, object}