forked from AkkomaGang/akkoma
FrontendStatic: make Router a runtime dep
Speeds up recompilation by removing compile-time cycles
This commit is contained in:
parent
c23b81e399
commit
721c966842
1 changed files with 5 additions and 4 deletions
|
@ -10,8 +10,6 @@ defmodule Pleroma.Web.Plugs.FrontendStatic do
|
||||||
"""
|
"""
|
||||||
@behaviour Plug
|
@behaviour Plug
|
||||||
|
|
||||||
@api_routes Pleroma.Web.Router.get_api_routes()
|
|
||||||
|
|
||||||
def file_path(path, frontend_type \\ :primary) do
|
def file_path(path, frontend_type \\ :primary) do
|
||||||
if configuration = Pleroma.Config.get([:frontends, frontend_type]) do
|
if configuration = Pleroma.Config.get([:frontends, frontend_type]) do
|
||||||
instance_static_path = Pleroma.Config.get([:instance, :static_dir], "instance/static")
|
instance_static_path = Pleroma.Config.get([:instance, :static_dir], "instance/static")
|
||||||
|
@ -55,10 +53,13 @@ defp invalid_path?([h | _], _match) when h in [".", "..", ""], do: true
|
||||||
defp invalid_path?([h | t], match), do: String.contains?(h, match) or invalid_path?(t)
|
defp invalid_path?([h | t], match), do: String.contains?(h, match) or invalid_path?(t)
|
||||||
defp invalid_path?([], _match), do: false
|
defp invalid_path?([], _match), do: false
|
||||||
|
|
||||||
defp api_route?([h | _]) when h in @api_routes, do: true
|
|
||||||
defp api_route?([_ | t]), do: api_route?(t)
|
|
||||||
defp api_route?([]), do: false
|
defp api_route?([]), do: false
|
||||||
|
|
||||||
|
defp api_route?([h | t]) do
|
||||||
|
api_routes = Pleroma.Web.Router.get_api_routes()
|
||||||
|
if h in api_routes, do: true, else: api_route?(t)
|
||||||
|
end
|
||||||
|
|
||||||
defp call_static(conn, opts, from) do
|
defp call_static(conn, opts, from) do
|
||||||
opts = Map.put(opts, :from, from)
|
opts = Map.put(opts, :from, from)
|
||||||
Plug.Static.call(conn, opts)
|
Plug.Static.call(conn, opts)
|
||||||
|
|
Loading…
Reference in a new issue