summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorIlja <pleroma@spectraltheorem.be>2022-05-08 18:10:40 +0000
committerHaelwenn <contact+git.pleroma.social@hacktivis.me>2022-05-08 18:10:40 +0000
commita8093732bd1f90a7b3c83b264cbddb96a578bafe (patch)
tree5e9c4cf672812d7d1bd24726ff90c8c555bd3be5 /lib
parentfa8e2ffa3f493d5b2911507b0ac06094615e9d8f (diff)
downloadpleroma-a8093732bd1f90a7b3c83b264cbddb96a578bafe.tar.gz
pleroma-a8093732bd1f90a7b3c83b264cbddb96a578bafe.zip
Also use actor_type to determine if an account is a bot in antiFollowbotPolicy
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/activity_pub/mrf/anti_followbot_policy.ex21
1 files changed, 17 insertions, 4 deletions
diff --git a/lib/pleroma/web/activity_pub/mrf/anti_followbot_policy.ex b/lib/pleroma/web/activity_pub/mrf/anti_followbot_policy.ex
index 851e95d22..627f52168 100644
--- a/lib/pleroma/web/activity_pub/mrf/anti_followbot_policy.ex
+++ b/lib/pleroma/web/activity_pub/mrf/anti_followbot_policy.ex
@@ -24,7 +24,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.AntiFollowbotPolicy do
defp score_displayname("fedibot"), do: 1.0
defp score_displayname(_), do: 0.0
- defp determine_if_followbot(%User{nickname: nickname, name: displayname}) do
+ defp determine_if_followbot(%User{nickname: nickname, name: displayname, actor_type: actor_type}) do
# nickname will be a binary string except when following a relay
nick_score =
if is_binary(nickname) do
@@ -45,19 +45,32 @@ defmodule Pleroma.Web.ActivityPub.MRF.AntiFollowbotPolicy do
0.0
end
- nick_score + name_score
+ # actor_type "Service" is a Bot account
+ actor_type_score =
+ if actor_type == "Service" do
+ 1.0
+ else
+ 0.0
+ end
+
+ nick_score + name_score + actor_type_score
end
defp determine_if_followbot(_), do: 0.0
+ defp bot_allowed?(%{"object" => target}, bot_actor) do
+ %User{} = user = normalize_by_ap_id(target)
+
+ User.following?(user, bot_actor)
+ end
+
@impl true
def filter(%{"type" => "Follow", "actor" => actor_id} = message) do
%User{} = actor = normalize_by_ap_id(actor_id)
score = determine_if_followbot(actor)
- # TODO: scan biography data for keywords and score it somehow.
- if score < 0.8 do
+ if score < 0.8 || bot_allowed?(message, actor) do
{:ok, message}
else
{:reject, "[AntiFollowbotPolicy] Scored #{actor_id} as #{score}"}