MRF: anti followbot: gracefully handle accounts without a display name
authorWilliam Pitcock <nenolod@dereferenced.org>
Thu, 7 Mar 2019 12:13:48 +0000 (12:13 +0000)
committerWilliam Pitcock <nenolod@dereferenced.org>
Thu, 7 Mar 2019 12:13:48 +0000 (12:13 +0000)
lib/pleroma/web/activity_pub/mrf/anti_followbot_policy.ex

index 7c6ad582ae9ab6e652d4224931d6451eed461407..34665a3a6999491b1ff3847bab127031e5f513c8 100644 (file)
@@ -23,15 +23,21 @@ defmodule Pleroma.Web.ActivityPub.MRF.AntiFollowbotPolicy do
   defp score_displayname(_), do: 0.0
 
   defp determine_if_followbot(%User{nickname: nickname, name: displayname}) do
+    # nickname will always be a binary string because it's generated by Pleroma.
     nick_score =
       nickname
       |> String.downcase()
       |> score_nickname()
 
+    # displayname will either be a binary string or nil, if a displayname isn't set.
     name_score =
-      displayname
-      |> String.downcase()
-      |> score_displayname()
+      if is_binary(displayname) do
+        displayname
+        |> String.downcase()
+        |> score_displayname()
+      else
+        0.0
+      end
 
     nick_score + name_score
   end