diff options
author | kaniini <nenolod@gmail.com> | 2018-12-23 11:28:43 +0000 |
---|---|---|
committer | kaniini <nenolod@gmail.com> | 2018-12-23 11:28:43 +0000 |
commit | 093d39b63416f597b336e1e2b7fb12af3591ef43 (patch) | |
tree | b7f7f9b8b09dd04537e3879833e72a61113cf00b /lib | |
parent | 61a88a6757bc557a370888d288f93681cff9668b (diff) | |
parent | a7f07bb6e56ad5173b9c2063d7f920cd102b4f2d (diff) | |
download | pleroma-093d39b63416f597b336e1e2b7fb12af3591ef43.tar.gz pleroma-093d39b63416f597b336e1e2b7fb12af3591ef43.zip |
Merge branch 'feature/hellthread-mitigation' into 'develop'
implement hellthread mitigation
Closes #474
See merge request pleroma/pleroma!588
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex b/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex new file mode 100644 index 000000000..55d6ff3f0 --- /dev/null +++ b/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex @@ -0,0 +1,18 @@ +defmodule Pleroma.Web.ActivityPub.MRF.HellthreadPolicy do + @behaviour Pleroma.Web.ActivityPub.MRF + + @impl true + def filter(%{"type" => "Create"} = object) do + threshold = Pleroma.Config.get([:mrf_hellthread, :threshold]) + recipients = (object["to"] || []) ++ (object["cc"] || []) + + if length(recipients) > threshold do + {:reject, nil} + else + {:ok, object} + end + end + + @impl true + def filter(object), do: {:ok, object} +end |