diff options
| author | Ivan Tashkinov <ivantashkinov@gmail.com> | 2020-03-11 09:15:55 +0300 |
|---|---|---|
| committer | Ivan Tashkinov <ivantashkinov@gmail.com> | 2020-03-11 09:15:55 +0300 |
| commit | 972889550da0f623693eeb3b2d1ca3025501e5eb (patch) | |
| tree | 175d795fcd44230b20913d162d96516bbab81989 /restarter/lib | |
| parent | 5fc92deef37dcc4db476520d89dd79e616356e63 (diff) | |
| parent | 953aece84866a89bd3de8f6d3f5d30e2f9cfb4f3 (diff) | |
| download | pleroma-972889550da0f623693eeb3b2d1ca3025501e5eb.tar.gz pleroma-972889550da0f623693eeb3b2d1ca3025501e5eb.zip | |
Merge remote-tracking branch 'remotes/origin/develop' into 1560-non-federating-instances-routes-restrictions
Diffstat (limited to 'restarter/lib')
| -rw-r--r-- | restarter/lib/pleroma.ex | 40 |
1 files changed, 30 insertions, 10 deletions
diff --git a/restarter/lib/pleroma.ex b/restarter/lib/pleroma.ex index d7817909d..7f08c637c 100644 --- a/restarter/lib/pleroma.ex +++ b/restarter/lib/pleroma.ex @@ -3,11 +3,21 @@ defmodule Restarter.Pleroma do 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, %{need_reboot?: false}} + 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?) @@ -29,41 +39,51 @@ defmodule Restarter.Pleroma 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} + {:reply, state[:need_reboot], state} end - def handle_cast(:refresh, _state) do - {:noreply, %{need_reboot?: false}} + 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, %{need_reboot: true} = state), do: {:noreply, state} def handle_cast(:need_reboot, state) do - {:noreply, Map.put(state, :need_reboot?, true)} + {: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.warn("pleroma restarted") - {:noreply, Map.put(state, :need_reboot?, false)} + {: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)} + {: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.warn("pleroma restarted") - {:noreply, Map.put(state, :after_boot, true)} + state = %{state | after_boot: true, rebooted: true} + {:noreply, state} end def handle_cast({:after_boot, _}, state) do do_restart(:pleroma) - {:noreply, Map.put(state, :after_boot, true)} + state = %{state | after_boot: true, rebooted: true} + {:noreply, state} end defp do_restart(app) do |
