diff options
author | lain <lain@soykaf.club> | 2020-08-05 15:59:30 +0000 |
---|---|---|
committer | lain <lain@soykaf.club> | 2020-08-05 15:59:30 +0000 |
commit | 9688e332d0985ccb1ea62206a62b21ecf65b0715 (patch) | |
tree | c893c4a2622a1d33e91b91825e35109c83fb44ba /lib | |
parent | 474aba984f2184d4f028c56f687d1a12f69d5c47 (diff) | |
parent | 8c57a299b463b7e5916addbbd3571b35e1742ebd (diff) | |
download | pleroma-9688e332d0985ccb1ea62206a62b21ecf65b0715.tar.gz |
Merge branch 'refactor/config-get' into 'develop'
Refactor Pleroma.Config.get to return consistent results for nil values
Closes #2001
See merge request pleroma/pleroma!2853
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/config.ex | 41 |
1 files changed, 30 insertions, 11 deletions
diff --git a/lib/pleroma/config.ex b/lib/pleroma/config.ex index cc80deff5..a8329cc1e 100644 --- a/lib/pleroma/config.ex +++ b/lib/pleroma/config.ex @@ -11,12 +11,10 @@ defmodule Pleroma.Config do def get([key], default), do: get(key, default) - def get([parent_key | keys], default) do - case :pleroma - |> Application.get_env(parent_key) - |> get_in(keys) do - nil -> default - any -> any + def get([_ | _] = path, default) do + case fetch(path) do + {:ok, value} -> value + :error -> default end end @@ -34,6 +32,24 @@ defmodule Pleroma.Config do end end + def fetch(key) when is_atom(key), do: fetch([key]) + + def fetch([root_key | keys]) do + Enum.reduce_while(keys, Application.fetch_env(:pleroma, root_key), fn + key, {:ok, config} when is_map(config) or is_list(config) -> + case Access.fetch(config, key) do + :error -> + {:halt, :error} + + value -> + {:cont, value} + end + + _key, _config -> + {:halt, :error} + end) + end + def put([key], value), do: put(key, value) def put([parent_key | keys], value) do @@ -50,12 +66,15 @@ defmodule Pleroma.Config do def delete([key]), do: delete(key) - def delete([parent_key | keys]) do - {_, parent} = - Application.get_env(:pleroma, parent_key) - |> get_and_update_in(keys, fn _ -> :pop end) + def delete([parent_key | keys] = path) do + with {:ok, _} <- fetch(path) do + {_, parent} = + parent_key + |> get() + |> get_and_update_in(keys, fn _ -> :pop end) - Application.put_env(:pleroma, parent_key, parent) + Application.put_env(:pleroma, parent_key, parent) + end end def delete(key) do |