Merge branch 'develop' into void-fix
ci/woodpecker/push/lint Pipeline was successful Details
ci/woodpecker/push/release Pipeline was successful Details
ci/woodpecker/push/test Pipeline was successful Details

This commit is contained in:
FloatingGhost 2022-07-14 11:49:38 +01:00
commit 64716b4833
4 changed files with 14 additions and 10 deletions

View File

@ -1,7 +0,0 @@
defmodule Akkoma.Web.Swagger do
alias Pleroma.Config
def ui_enabled? do
Config.get([:frontends, :swagger, "enabled"])
end
end

View File

@ -72,7 +72,7 @@ defmodule Pleroma.Web.Endpoint do
at: "/akkoma/swaggerui",
frontend_type: :swagger,
gzip: true,
if: &Akkoma.Web.Swagger.ui_enabled?/0,
if: &Pleroma.Web.Swagger.ui_enabled?/0,
cache_control_for_etags: @static_cache_control,
headers: %{
"cache-control" => @static_cache_control

View File

@ -31,13 +31,13 @@ defmodule Pleroma.Web.Plugs.FrontendStatic do
|> Keyword.put(:from, "__unconfigured_frontend_static_plug")
|> Plug.Static.init()
|> Map.put(:frontend_type, opts[:frontend_type])
|> Map.put(:if, Keyword.get(opts, :if, fn -> true end))
|> Map.put(:if, Keyword.get(opts, :if, true))
end
def call(conn, opts) do
with false <- api_route?(conn.path_info),
false <- invalid_path?(conn.path_info),
true <- opts[:if].(),
true <- enabled?(opts[:if]),
frontend_type <- Map.get(opts, :frontend_type, :primary),
path when not is_nil(path) <- file_path("", frontend_type) do
call_static(conn, opts, path)
@ -47,6 +47,10 @@ defmodule Pleroma.Web.Plugs.FrontendStatic do
end
end
defp enabled?(if_opt) when is_function(if_opt), do: if_opt.()
defp enabled?(true), do: true
defp enabled?(_), do: false
defp invalid_path?(list) do
invalid_path?(list, :binary.compile_pattern(["/", "\\", ":", "\0"]))
end

View File

@ -0,0 +1,7 @@
defmodule Pleroma.Web.Swagger do
alias Pleroma.Config
def ui_enabled? do
Config.get([:frontends, :swagger, "enabled"], false)
end
end