Merge remote-tracking branch 'remotes/origin/develop' into 2168-media-preview-proxy
[akkoma] / lib / pleroma / web / admin_api / views / config_view.ex
index a31f1041fd1e3334d8ef17f9a14a1d86f3ea9a6c..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_to_map(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