2020-01-17 09:45:44 +01:00
|
|
|
defmodule Pleroma.Config.Loader do
|
|
|
|
# TODO: add support for releases
|
|
|
|
if Code.ensure_loaded?(Config.Reader) do
|
|
|
|
@spec load() :: map()
|
|
|
|
def load do
|
2020-01-17 14:28:44 +01:00
|
|
|
config = load("config/config.exs")
|
|
|
|
env_config = load("config/#{Mix.env()}.exs")
|
2020-01-17 09:45:44 +01:00
|
|
|
|
|
|
|
Config.Reader.merge(config, env_config)
|
|
|
|
end
|
2020-01-17 14:28:44 +01:00
|
|
|
|
|
|
|
@spec load(Path.t()) :: keyword()
|
|
|
|
def load(path), do: Config.Reader.read!(path)
|
2020-01-17 09:45:44 +01:00
|
|
|
else
|
|
|
|
# support for Elixir less than 1.9
|
|
|
|
@spec load() :: map()
|
|
|
|
def load do
|
2020-01-17 14:28:44 +01:00
|
|
|
{config, _paths} = load("config/config.exs")
|
|
|
|
{env_config, _paths} = load("config/#{Mix.env()}.exs")
|
2020-01-17 09:45:44 +01:00
|
|
|
|
|
|
|
Mix.Config.merge(config, env_config)
|
|
|
|
end
|
2020-01-17 14:28:44 +01:00
|
|
|
|
|
|
|
@spec load(Path.t()) :: keyword()
|
|
|
|
def load(path) do
|
|
|
|
{config, _paths} = Mix.Config.eval!(path)
|
|
|
|
config
|
|
|
|
end
|
2020-01-17 09:45:44 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
defmodule Pleroma.Config.Holder do
|
|
|
|
@config Pleroma.Config.Loader.load()
|
|
|
|
|
|
|
|
@spec config() :: keyword()
|
|
|
|
def config do
|
|
|
|
@config
|
|
|
|
|> Keyword.keys()
|
|
|
|
|> Enum.map(&filter(&1, config(&1)))
|
|
|
|
|> List.flatten()
|
|
|
|
end
|
|
|
|
|
|
|
|
@spec config(atom()) :: any()
|
|
|
|
def config(group), do: @config[group]
|
|
|
|
|
|
|
|
@spec config(atom(), atom()) :: any()
|
|
|
|
def config(group, key), do: @config[group][key]
|
|
|
|
|
|
|
|
defp filter(group, settings) when group not in [:swarm] do
|
|
|
|
filtered =
|
|
|
|
Enum.reject(settings, fn {k, _v} ->
|
|
|
|
k in [Pleroma.Repo, Pleroma.Web.Endpoint, :env, :configurable_from_database] or
|
|
|
|
(group == :phoenix and k == :serve_endpoints)
|
|
|
|
end)
|
|
|
|
|
|
|
|
{group, filtered}
|
|
|
|
end
|
|
|
|
|
|
|
|
defp filter(_, _), do: []
|
|
|
|
end
|