Pleroma.Web.Nodeinfo.NodeinfoController: Further transparency, breaks API of previous one
[akkoma] / lib / pleroma / web / nodeinfo / nodeinfo_controller.ex
index 2fab6027499caa331870870687da1c6770fd2259..3b495ad86d96631087a120e68a85f24c8e8cdd0d 100644 (file)
@@ -3,6 +3,7 @@ defmodule Pleroma.Web.Nodeinfo.NodeinfoController do
 
   alias Pleroma.Stats
   alias Pleroma.Web
+  alias Pleroma.{User, Repo}
 
   def schemas(conn, _params) do
     response = %{
@@ -22,7 +23,22 @@ defmodule Pleroma.Web.Nodeinfo.NodeinfoController do
     instance = Application.get_env(:pleroma, :instance)
     media_proxy = Application.get_env(:pleroma, :media_proxy)
     suggestions = Application.get_env(:pleroma, :suggestions)
+    chat = Application.get_env(:pleroma, :chat)
+    gopher = Application.get_env(:pleroma, :gopher)
     stats = Stats.get_stats()
+    mrf_simple = Application.get_env(:pleroma, :mrf_simple)
+
+    mrf_policies =
+      if(is_list(instance.rewrite_policy)) do
+        instance.rewrite_policy
+      else
+        [instance.rewrite_policy]
+      end
+
+    staff_accounts =
+      User.moderator_user_query()
+      |> Repo.all()
+      |> Enum.map(fn u -> u.ap_id end)
 
     response = %{
       version: "2.0",
@@ -51,7 +67,16 @@ defmodule Pleroma.Web.Nodeinfo.NodeinfoController do
           enabled: Keyword.get(suggestions, :enabled, false),
           thirdPartyEngine: Keyword.get(suggestions, :third_party_engine, ""),
           timeout: Keyword.get(suggestions, :timeout, 5000),
+          limit: Keyword.get(suggestions, :limit, 23),
           web: Keyword.get(suggestions, :web, "")
+        },
+        staffAccounts: staff_accounts,
+        chat: Keyword.get(chat, :enabled),
+        gopher: Keyword.get(gopher, :enabled),
+        federation: %{
+          mrf_policies: mrf_policies,
+          mrf_simple: mrf_simple,
+          quarantined_instances: instance.quarantined_instances
         }
       }
     }