diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/application.ex | 4 | ||||
| -rw-r--r-- | lib/pleroma/web/push/impl.ex | 6 | ||||
| -rw-r--r-- | lib/pleroma/web/push/push.ex | 48 | 
3 files changed, 15 insertions, 43 deletions
| diff --git a/lib/pleroma/application.ex b/lib/pleroma/application.ex index f0cb7d9a8..eeb415084 100644 --- a/lib/pleroma/application.ex +++ b/lib/pleroma/application.ex @@ -111,8 +111,8 @@ defmodule Pleroma.Application do          [            worker(Pleroma.Web.Federator.RetryQueue, []),            worker(Pleroma.Stats, []), -          worker(Pleroma.Web.Push, []), -          worker(Task, [&Pleroma.Web.Federator.init/0], restart: :temporary) +          worker(Task, [&Pleroma.Web.Push.init/0], restart: :temporary, id: :web_push_init), +          worker(Task, [&Pleroma.Web.Federator.init/0], restart: :temporary, id: :federator_init)          ] ++          streamer_child() ++          chat_child() ++ diff --git a/lib/pleroma/web/push/impl.ex b/lib/pleroma/web/push/impl.ex index 863573185..2233480c5 100644 --- a/lib/pleroma/web/push/impl.ex +++ b/lib/pleroma/web/push/impl.ex @@ -19,8 +19,8 @@ defmodule Pleroma.Web.Push.Impl do    @types ["Create", "Follow", "Announce", "Like"]    @doc "Performs sending notifications for user subscriptions" -  @spec perform_send(Notification.t()) :: list(any) -  def perform_send( +  @spec perform(Notification.t()) :: list(any) | :error +  def perform(          %{activity: %{data: %{"type" => activity_type}, id: activity_id}, user_id: user_id} =            notif        ) @@ -50,7 +50,7 @@ defmodule Pleroma.Web.Push.Impl do      end    end -  def perform_send(_) do +  def perform(_) do      Logger.warn("Unknown notification type")      :error    end diff --git a/lib/pleroma/web/push/push.ex b/lib/pleroma/web/push/push.ex index 5259e8e33..729dad02a 100644 --- a/lib/pleroma/web/push/push.ex +++ b/lib/pleroma/web/push/push.ex @@ -3,18 +3,20 @@  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.Web.Push do -  use GenServer -    alias Pleroma.Web.Push.Impl    require Logger -  ############## -  # Client API # -  ############## +  def init do +    unless enabled() do +      Logger.warn(""" +      VAPID key pair is not found. If you wish to enabled web push, please run + +          mix web_push.gen.keypair -  def start_link do -    GenServer.start_link(__MODULE__, :ok, name: __MODULE__) +      and add the resulting output to your configuration file. +      """) +    end    end    def vapid_config do @@ -30,35 +32,5 @@ defmodule Pleroma.Web.Push do    end    def send(notification), -    do: GenServer.cast(__MODULE__, {:send, notification}) - -  #################### -  # Server Callbacks # -  #################### - -  @impl true -  def init(:ok) do -    if enabled() do -      {:ok, nil} -    else -      Logger.warn(""" -      VAPID key pair is not found. If you wish to enabled web push, please run - -          mix web_push.gen.keypair - -      and add the resulting output to your configuration file. -      """) - -      :ignore -    end -  end - -  @impl true -  def handle_cast({:send, notification}, state) do -    if enabled() do -      Impl.perform_send(notification) -    end - -    {:noreply, state} -  end +    do: PleromaJobQueue.enqueue(:web_push, Impl, [notification])  end | 
