header = config_header()
- shell_info("#{header}")
+ settings =
+ ConfigDB
+ |> Repo.all()
+ |> Enum.sort()
- ConfigDB
- |> Repo.all()
- |> Enum.each(&dump(&1))
+ unless settings == [] do
+ shell_info("#{header}")
+
+ settings |> Enum.each(&dump(&1))
+ else
+ shell_error("No settings in ConfigDB.")
+ end
else
_ -> configdb_not_enabled()
end
end
- def run(["dump" | dbkey]) do
+ def run(["dump", group, key]) do
with true <- Pleroma.Config.get([:configurable_from_database]) do
start_pleroma()
- dbkey = dbkey |> List.first() |> String.to_atom()
+ group = maybe_atomize(group)
+ key = maybe_atomize(key)
- ConfigDB
- |> Repo.all()
- |> Enum.filter(fn x ->
- if x.key == dbkey do
- x |> dump
- end
- end)
+ dump_key(group, key)
else
_ -> configdb_not_enabled()
end
end
- def run(["keylist"]) do
+ def run(["dump", group]) do
with true <- Pleroma.Config.get([:configurable_from_database]) do
start_pleroma()
- keys =
+ group = maybe_atomize(group)
+
+ dump_group(group)
+ else
+ _ -> configdb_not_enabled()
+ end
+ end
+
+ def run(["groups"]) do
+ with true <- Pleroma.Config.get([:configurable_from_database]) do
+ start_pleroma()
+
+ groups =
ConfigDB
|> Repo.all()
- |> Enum.map(fn x -> x.key end)
+ |> Enum.map(fn x -> x.group end)
+ |> Enum.sort()
+ |> Enum.uniq()
- if length(keys) > 0 do
- shell_info("The following configuration keys are set in ConfigDB:\r\n")
- keys |> Enum.each(fn x -> shell_info("- #{x}") end)
+ if length(groups) > 0 do
+ shell_info("The following configuration groups are set in ConfigDB:\r\n")
+ groups |> Enum.each(fn x -> shell_info("- #{x}") end)
shell_info("\r\n")
end
else
with true <- Pleroma.Config.get([:configurable_from_database]) do
start_pleroma()
- Ecto.Adapters.SQL.query!(Repo, "TRUNCATE config;")
- Ecto.Adapters.SQL.query!(Repo, "ALTER SEQUENCE config_id_seq RESTART;")
+ shell_info("The following settings will be permanently removed:")
+
+ ConfigDB
+ |> Repo.all()
+ |> Enum.sort()
+ |> Enum.each(&dump(&1))
+
+ shell_error("\nTHIS CANNOT BE UNDONE!")
+
+ if shell_prompt("Are you sure you want to continue?", "n") in ~w(Yn Y y) do
+ Ecto.Adapters.SQL.query!(Repo, "TRUNCATE config;")
+ Ecto.Adapters.SQL.query!(Repo, "ALTER SEQUENCE config_id_seq RESTART;")
- shell_info("The ConfigDB settings have been removed from the database.")
+ shell_info("The ConfigDB settings have been removed from the database.")
+ else
+ shell_error("No changes made.")
+ end
else
_ -> configdb_not_enabled()
end
end
- def run(["keydel" | dbkey]) do
- unless [] == dbkey do
- with true <- Pleroma.Config.get([:configurable_from_database]) do
- start_pleroma()
+ def run(["delete", group]) do
+ with true <- Pleroma.Config.get([:configurable_from_database]) do
+ start_pleroma()
+
+ group = maybe_atomize(group)
- dbkey = dbkey |> List.first() |> String.to_atom()
+ if group_exists?(group) do
+ shell_info("The following settings will be removed from ConfigDB:\n")
+ dump_group(group)
+
+ if shell_prompt("Are you sure you want to continue?", "n") in ~w(Yn Y y) do
+ ConfigDB
+ |> Repo.all()
+ |> Enum.filter(fn x ->
+ if x.group == group do
+ x |> delete(true)
+ end
+ end)
+ else
+ shell_error("No changes made.")
+ end
+ else
+ shell_error("No settings in ConfigDB for :#{group}. Aborting.")
+ end
+ else
+ _ -> configdb_not_enabled()
+ end
+ end
+
+ def run(["delete", group, key]) do
+ with true <- Pleroma.Config.get([:configurable_from_database]) do
+ start_pleroma()
+
+ group = maybe_atomize(group)
+ key = maybe_atomize(key)
+
+ if shell_prompt("Are you sure you want to continue?", "n") in ~w(Yn Y y) do
ConfigDB
|> Repo.all()
|> Enum.filter(fn x ->
- if x.key == dbkey do
+ if x.group == group and x.key == key do
x |> delete(true)
end
end)
else
- _ -> configdb_not_enabled()
+ shell_error("No changes made.")
end
else
- shell_error(
- "You must provide a key to delete. Use the keylist command to get a list of valid keys."
- )
+ _ -> configdb_not_enabled()
end
end
defp delete(config, true) do
{:ok, _} = Repo.delete(config)
- shell_info("#{config.key} deleted from the ConfigDB.")
+
+ shell_info(
+ "config #{inspect(config.group)}, #{inspect(config.key)} deleted from the ConfigDB."
+ )
end
defp delete(_config, _), do: :ok
"ConfigDB not enabled. Please check the value of :configurable_from_database in your configuration."
)
end
+
+ defp dump_key(group, key) when is_atom(group) and is_atom(key) do
+ ConfigDB
+ |> Repo.all()
+ |> Enum.filter(fn x ->
+ if x.group == group && x.key == key do
+ x |> dump
+ end
+ end)
+ end
+
+ defp dump_group(group) when is_atom(group) do
+ ConfigDB
+ |> Repo.all()
+ |> Enum.filter(fn x ->
+ if x.group == group do
+ x |> dump
+ end
+ end)
+ end
+
+ defp group_exists?(group) when is_atom(group) do
+ result =
+ ConfigDB
+ |> Repo.all()
+ |> Enum.filter(fn x ->
+ if x.group == group do
+ x
+ end
+ end)
+
+ unless result == [] do
+ true
+ else
+ false
+ end
+ end
+
+ def maybe_atomize(arg) when is_atom(arg), do: arg
+
+ def maybe_atomize(arg) when is_binary(arg) do
+ chars = String.codepoints(arg)
+
+ if "." in chars do
+ :"Elixir.#{arg}"
+ else
+ String.to_atom(arg)
+ end
+ end
end