Merge branch 'preload-data' into 'develop'
[akkoma] / lib / pleroma / web / admin_api / views / config_view.ex
index 49add0b6e286a98e434daf8f617bc1f237a17e72..d2d8b59070c0e942ee48ed8700b3abeb5bbbe447 100644 (file)
@@ -1,21 +1,30 @@
 # Pleroma: A lightweight social networking server
-# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
+# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
 # SPDX-License-Identifier: AGPL-3.0-only
 
 defmodule Pleroma.Web.AdminAPI.ConfigView do
   use Pleroma.Web, :view
 
-  def render("index.json", %{configs: configs}) do
+  alias Pleroma.ConfigDB
+
+  def render("index.json", %{configs: configs} = params) do
     %{
-      configs: render_many(configs, __MODULE__, "show.json", as: :config)
+      configs: render_many(configs, __MODULE__, "show.json", as: :config),
+      need_reboot: params[:need_reboot]
     }
   end
 
   def render("show.json", %{config: config}) do
-    %{
-      key: config.key,
-      group: config.group,
-      value: Pleroma.Web.AdminAPI.Config.from_binary_with_convert(config.value)
+    map = %{
+      key: ConfigDB.to_json_types(config.key),
+      group: ConfigDB.to_json_types(config.group),
+      value: ConfigDB.to_json_types(config.value)
     }
+
+    if config.db != [] do
+      Map.put(map, :db, config.db)
+    else
+      map
+    end
   end
 end