MRF Transparency
authorHaelwenn (lanodan) Monnier <contact@hacktivis.me>
Thu, 4 Oct 2018 11:37:17 +0000 (13:37 +0200)
committerHaelwenn (lanodan) Monnier <contact@hacktivis.me>
Fri, 5 Oct 2018 18:09:08 +0000 (20:09 +0200)
lib/pleroma/web/nodeinfo/nodeinfo_controller.ex

index 3b495ad86d96631087a120e68a85f24c8e8cdd0d..1f1b0282c30970e87aca6494ac83739588958e65 100644 (file)
@@ -28,11 +28,23 @@ defmodule Pleroma.Web.Nodeinfo.NodeinfoController do
     stats = Stats.get_stats()
     mrf_simple = Application.get_env(:pleroma, :mrf_simple)
 
+    mrf_policies = Keyword.get(instance, :rewrite_policy)
+
     mrf_policies =
-      if(is_list(instance.rewrite_policy)) do
-        instance.rewrite_policy
+      if(is_list(mrf_policies)) do
+        mrf_policies
+        |> Enum.map(fn policy -> to_string(policy) |> String.split(".") |> List.last() end)
+      else
+        [to_string(mrf_policies) |> String.split(".") |> List.last()]
+      end
+
+    quarantined = Keyword.get(instance, :quarantined_instances)
+
+    quarantined =
+      if is_list(quarantined) do
+        quarantined
       else
-        [instance.rewrite_policy]
+        []
       end
 
     staff_accounts =
@@ -76,7 +88,7 @@ defmodule Pleroma.Web.Nodeinfo.NodeinfoController do
         federation: %{
           mrf_policies: mrf_policies,
           mrf_simple: mrf_simple,
-          quarantined_instances: instance.quarantined_instances
+          quarantined_instances: quarantined
         }
       }
     }