1
0
Fork 0
forked from AkkomaGang/akkoma
akkoma/lib/pleroma/config/transfer_task.ex

60 lines
1.5 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Config.TransferTask do
use Task
alias Pleroma.Web.AdminAPI.Config
2019-08-14 15:55:17 +00:00
def start_link(_) do
load_and_update_env()
if Pleroma.Config.get(:env) == :test, do: Ecto.Adapters.SQL.Sandbox.checkin(Pleroma.Repo)
:ignore
end
def load_and_update_env do
2019-06-16 10:01:15 +00:00
if Pleroma.Config.get([:instance, :dynamic_configuration]) and
Ecto.Adapters.SQL.table_exists?(Pleroma.Repo, "config") do
2019-06-23 05:16:16 +00:00
for_restart =
Pleroma.Repo.all(Config)
|> Enum.map(&update_env(&1))
# We need to restart applications for loaded settings take effect
for_restart
|> Enum.reject(&(&1 in [:pleroma, :ok]))
|> Enum.each(fn app ->
Application.stop(app)
:ok = Application.start(app)
end)
end
end
defp update_env(setting) do
try do
key =
if String.starts_with?(setting.key, "Pleroma.") do
"Elixir." <> setting.key
else
2019-07-15 08:00:55 +00:00
String.trim_leading(setting.key, ":")
end
2019-06-23 05:16:16 +00:00
group = String.to_existing_atom(setting.group)
Application.put_env(
2019-06-23 05:16:16 +00:00
group,
String.to_existing_atom(key),
Config.from_binary(setting.value)
)
2019-06-23 05:16:16 +00:00
group
rescue
e ->
require Logger
Logger.warn(
"updating env causes error, key: #{inspect(setting.key)}, error: #{inspect(e)}"
)
end
end
end