diff options
| author | Egor Kislitsyn <egor@kislitsyn.com> | 2020-05-28 23:11:12 +0400 | 
|---|---|---|
| committer | Egor Kislitsyn <egor@kislitsyn.com> | 2020-05-28 23:11:12 +0400 | 
| commit | 06f20e918129b1f434783b64d59b5ae6b4b4ed51 (patch) | |
| tree | 42b0611b42bbd232233c89c4a3d6c7c7f6bb01da /lib | |
| parent | d1ee3527ef8062c34e222a1c7084c207b80fe4db (diff) | |
| download | pleroma-06f20e918129b1f434783b64d59b5ae6b4b4ed51.tar.gz pleroma-06f20e918129b1f434783b64d59b5ae6b4b4ed51.zip | |
Add OpenApi spec to AdminAPI.ConfigController
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/web/admin_api/controllers/config_controller.ex | 21 | ||||
| -rw-r--r-- | lib/pleroma/web/api_spec/operations/admin/config_operation.ex | 142 | 
2 files changed, 154 insertions, 9 deletions
| diff --git a/lib/pleroma/web/admin_api/controllers/config_controller.ex b/lib/pleroma/web/admin_api/controllers/config_controller.ex index 742980976..e221d9418 100644 --- a/lib/pleroma/web/admin_api/controllers/config_controller.ex +++ b/lib/pleroma/web/admin_api/controllers/config_controller.ex @@ -11,23 +11,26 @@ defmodule Pleroma.Web.AdminAPI.ConfigController do    @descriptions Pleroma.Docs.JSON.compile() +  plug(Pleroma.Web.ApiSpec.CastAndValidate) +  plug(OAuthScopesPlug, %{scopes: ["write"], admin: true} when action == :update) +    plug(      OAuthScopesPlug,      %{scopes: ["read"], admin: true}      when action in [:show, :descriptions]    ) -  plug(OAuthScopesPlug, %{scopes: ["write"], admin: true} when action == :update) -    action_fallback(Pleroma.Web.AdminAPI.FallbackController) +  defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.Admin.ConfigOperation +    def descriptions(conn, _params) do      descriptions = Enum.filter(@descriptions, &whitelisted_config?/1)      json(conn, descriptions)    end -  def show(conn, %{"only_db" => true}) do +  def show(conn, %{only_db: true}) do      with :ok <- configurable_from_database() do        configs = Pleroma.Repo.all(ConfigDB)        render(conn, "index.json", %{configs: configs}) @@ -73,16 +76,16 @@ defmodule Pleroma.Web.AdminAPI.ConfigController do      end    end -  def update(conn, %{"configs" => configs}) do +  def update(%{body_params: %{configs: configs}} = conn, _) do      with :ok <- configurable_from_database() do        results =          configs          |> Enum.filter(&whitelisted_config?/1)          |> Enum.map(fn -          %{"group" => group, "key" => key, "delete" => true} = params -> -            ConfigDB.delete(%{group: group, key: key, subkeys: params["subkeys"]}) +          %{group: group, key: key, delete: true} = params -> +            ConfigDB.delete(%{group: group, key: key, subkeys: params[:subkeys]}) -          %{"group" => group, "key" => key, "value" => value} -> +          %{group: group, key: key, value: value} ->              ConfigDB.update_or_create(%{group: group, key: key, value: value})          end)          |> Enum.reject(fn {result, _} -> result == :error end) @@ -140,11 +143,11 @@ defmodule Pleroma.Web.AdminAPI.ConfigController do      end    end -  defp whitelisted_config?(%{"group" => group, "key" => key}) do +  defp whitelisted_config?(%{group: group, key: key}) do      whitelisted_config?(group, key)    end -  defp whitelisted_config?(%{:group => group} = config) do +  defp whitelisted_config?(%{group: group} = config) do      whitelisted_config?(group, config[:key])    end  end diff --git a/lib/pleroma/web/api_spec/operations/admin/config_operation.ex b/lib/pleroma/web/api_spec/operations/admin/config_operation.ex new file mode 100644 index 000000000..7b38a2ef4 --- /dev/null +++ b/lib/pleroma/web/api_spec/operations/admin/config_operation.ex @@ -0,0 +1,142 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ApiSpec.Admin.ConfigOperation do +  alias OpenApiSpex.Operation +  alias OpenApiSpex.Schema +  alias Pleroma.Web.ApiSpec.Schemas.ApiError + +  import Pleroma.Web.ApiSpec.Helpers + +  def open_api_operation(action) do +    operation = String.to_existing_atom("#{action}_operation") +    apply(__MODULE__, operation, []) +  end + +  def show_operation do +    %Operation{ +      tags: ["Admin", "Config"], +      summary: "Get list of merged default settings with saved in database", +      operationId: "AdminAPI.ConfigController.show", +      parameters: [ +        Operation.parameter( +          :only_db, +          :query, +          %Schema{type: :boolean, default: false}, +          "Get only saved in database settings" +        ) +      ], +      security: [%{"oAuth" => ["read"]}], +      responses: %{ +        200 => Operation.response("Config", "application/json", config_response()), +        400 => Operation.response("Bad Request", "application/json", ApiError) +      } +    } +  end + +  def update_operation do +    %Operation{ +      tags: ["Admin", "Config"], +      summary: "Update config settings", +      operationId: "AdminAPI.ConfigController.update", +      security: [%{"oAuth" => ["write"]}], +      requestBody: +        request_body("Parameters", %Schema{ +          type: :object, +          properties: %{ +            configs: %Schema{ +              type: :array, +              items: %Schema{ +                type: :object, +                properties: %{ +                  group: %Schema{type: :string}, +                  key: %Schema{type: :string}, +                  value: any(), +                  delete: %Schema{type: :boolean}, +                  subkeys: %Schema{type: :array, items: %Schema{type: :string}} +                } +              } +            } +          } +        }), +      responses: %{ +        200 => Operation.response("Config", "application/json", config_response()), +        400 => Operation.response("Bad Request", "application/json", ApiError) +      } +    } +  end + +  def descriptions_operation do +    %Operation{ +      tags: ["Admin", "Config"], +      summary: "Get JSON with config descriptions.", +      operationId: "AdminAPI.ConfigController.descriptions", +      security: [%{"oAuth" => ["read"]}], +      responses: %{ +        200 => +          Operation.response("Config Descriptions", "application/json", %Schema{ +            type: :array, +            items: %Schema{ +              type: :object, +              properties: %{ +                group: %Schema{type: :string}, +                key: %Schema{type: :string}, +                type: %Schema{oneOf: [%Schema{type: :string}, %Schema{type: :array}]}, +                description: %Schema{type: :string}, +                children: %Schema{ +                  type: :array, +                  items: %Schema{ +                    type: :object, +                    properties: %{ +                      key: %Schema{type: :string}, +                      type: %Schema{oneOf: [%Schema{type: :string}, %Schema{type: :array}]}, +                      description: %Schema{type: :string}, +                      suggestions: %Schema{type: :array} +                    } +                  } +                } +              } +            } +          }), +        400 => Operation.response("Bad Request", "application/json", ApiError) +      } +    } +  end + +  defp any do +    %Schema{ +      oneOf: [ +        %Schema{type: :array}, +        %Schema{type: :object}, +        %Schema{type: :string}, +        %Schema{type: :integer}, +        %Schema{type: :boolean} +      ] +    } +  end + +  defp config_response do +    %Schema{ +      type: :object, +      properties: %{ +        configs: %Schema{ +          type: :array, +          items: %Schema{ +            type: :object, +            properties: %{ +              group: %Schema{type: :string}, +              key: %Schema{type: :string}, +              value: any() +            } +          } +        }, +        need_reboot: %Schema{ +          type: :boolean, +          description: +            "If `need_reboot` is `true`, instance must be restarted, so reboot time settings can take effect" +        } +      } +    } +  end +end | 
