diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/mix/pleroma.ex | 13 | ||||
| -rw-r--r-- | lib/pleroma/config/transfer_task.ex | 6 | 
2 files changed, 18 insertions, 1 deletions
diff --git a/lib/mix/pleroma.ex b/lib/mix/pleroma.ex index 90f8c8008..3ad6edbfb 100644 --- a/lib/mix/pleroma.ex +++ b/lib/mix/pleroma.ex @@ -12,6 +12,19 @@ defmodule Mix.Pleroma do      end      {:ok, _} = Application.ensure_all_started(:pleroma) + +    if Pleroma.Config.get(:env) not in [:test, :benchmark] do +      pleroma_rebooted?() +    end +  end + +  defp pleroma_rebooted? do +    if Restarter.Pleroma.rebooted?() do +      :ok +    else +      Process.sleep(10) +      pleroma_rebooted?() +    end    end    def load_pleroma do diff --git a/lib/pleroma/config/transfer_task.ex b/lib/pleroma/config/transfer_task.ex index 1846aa22c..435fc7450 100644 --- a/lib/pleroma/config/transfer_task.ex +++ b/lib/pleroma/config/transfer_task.ex @@ -42,7 +42,8 @@ defmodule Pleroma.Config.TransferTask do    @spec load_and_update_env([ConfigDB.t()]) :: :ok | false    def load_and_update_env(deleted \\ [], restart_pleroma? \\ true) do -    with true <- Pleroma.Config.get(:configurable_from_database), +    with {:configurable, true} <- +           {:configurable, Pleroma.Config.get(:configurable_from_database)},           true <- Ecto.Adapters.SQL.table_exists?(Repo, "config"),           started_applications <- Application.started_applications() do        # We need to restart applications for loaded settings take effect @@ -65,12 +66,15 @@ defmodule Pleroma.Config.TransferTask do          if :pleroma in applications do            List.delete(applications, :pleroma) ++ [:pleroma]          else +          Restarter.Pleroma.rebooted()            applications          end        Enum.each(applications, &restart(started_applications, &1, Pleroma.Config.get(:env)))        :ok +    else +      {:configurable, false} -> Restarter.Pleroma.rebooted()      end    end  | 
