diff options
Diffstat (limited to 'restarter')
-rw-r--r-- | restarter/lib/pleroma.ex | 94 | ||||
-rw-r--r-- | restarter/lib/restarter.ex | 8 | ||||
-rw-r--r-- | restarter/mix.exs | 21 |
3 files changed, 0 insertions, 123 deletions
diff --git a/restarter/lib/pleroma.ex b/restarter/lib/pleroma.ex deleted file mode 100644 index 149a569ce..000000000 --- a/restarter/lib/pleroma.ex +++ /dev/null @@ -1,94 +0,0 @@ -defmodule Restarter.Pleroma do - use GenServer - - require Logger - - @init_state %{need_reboot: false, rebooted: false, after_boot: false} - - def start_link(_) do - GenServer.start_link(__MODULE__, [], name: __MODULE__) - end - - def init(_), do: {:ok, @init_state} - - def rebooted? do - GenServer.call(__MODULE__, :rebooted?) - end - - def rebooted do - GenServer.cast(__MODULE__, :rebooted) - end - - def need_reboot? do - GenServer.call(__MODULE__, :need_reboot?) - end - - def need_reboot do - GenServer.cast(__MODULE__, :need_reboot) - end - - def refresh do - GenServer.cast(__MODULE__, :refresh) - end - - def restart(env, delay) do - GenServer.cast(__MODULE__, {:restart, env, delay}) - end - - def restart_after_boot(env) do - GenServer.cast(__MODULE__, {:after_boot, env}) - end - - def handle_call(:rebooted?, _from, state) do - {:reply, state[:rebooted], state} - end - - def handle_call(:need_reboot?, _from, state) do - {:reply, state[:need_reboot], state} - end - - def handle_cast(:rebooted, state) do - {:noreply, Map.put(state, :rebooted, true)} - end - - def handle_cast(:need_reboot, %{need_reboot: true} = state), do: {:noreply, state} - - def handle_cast(:need_reboot, state) do - {:noreply, Map.put(state, :need_reboot, true)} - end - - def handle_cast(:refresh, _state) do - {:noreply, @init_state} - end - - def handle_cast({:restart, :test, _}, state) do - Logger.debug("pleroma manually restarted") - {:noreply, Map.put(state, :need_reboot, false)} - end - - def handle_cast({:restart, _, delay}, state) do - Process.sleep(delay) - do_restart(:pleroma) - {:noreply, Map.put(state, :need_reboot, false)} - end - - def handle_cast({:after_boot, _}, %{after_boot: true} = state), do: {:noreply, state} - - def handle_cast({:after_boot, :test}, state) do - Logger.debug("pleroma restarted after boot") - state = %{state | after_boot: true, rebooted: true} - {:noreply, state} - end - - def handle_cast({:after_boot, _}, state) do - do_restart(:pleroma) - state = %{state | after_boot: true, rebooted: true} - {:noreply, state} - end - - defp do_restart(app) do - :ok = Application.ensure_started(app) - :ok = Application.stop(app) - :ok = Application.start(app) - end -end diff --git a/restarter/lib/restarter.ex b/restarter/lib/restarter.ex deleted file mode 100644 index eadd86f89..000000000 --- a/restarter/lib/restarter.ex +++ /dev/null @@ -1,8 +0,0 @@ -defmodule Restarter do - use Application - - def start(_, _) do - opts = [strategy: :one_for_one, name: Restarter.Supervisor] - Supervisor.start_link([Restarter.Pleroma], opts) - end -end diff --git a/restarter/mix.exs b/restarter/mix.exs deleted file mode 100644 index b0908aece..000000000 --- a/restarter/mix.exs +++ /dev/null @@ -1,21 +0,0 @@ -defmodule Restarter.MixProject do - use Mix.Project - - def project do - [ - app: :restarter, - version: "0.1.0", - elixir: "~> 1.8", - start_permanent: Mix.env() == :prod, - deps: deps() - ] - end - - def application do - [ - mod: {Restarter, []} - ] - end - - defp deps, do: [] -end |