X-Git-Url: https://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Fweb%2Fpush%2Fpush.ex;h=5259e8e33083c248f38621fcfdc693e63dcb2fc9;hb=fb82f6fc7c5453e34e619c54a88e64e99deb58b4;hp=8b59e54cbae5170c3aaa0d97ce153377d9300698;hpb=d8984b7bf83e1ee076a73aab682db0f2673e3735;p=akkoma diff --git a/lib/pleroma/web/push/push.ex b/lib/pleroma/web/push/push.ex index 8b59e54cb..5259e8e33 100644 --- a/lib/pleroma/web/push/push.ex +++ b/lib/pleroma/web/push/push.ex @@ -1,123 +1,64 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors +# SPDX-License-Identifier: AGPL-3.0-only + defmodule Pleroma.Web.Push do use GenServer - alias Pleroma.{Repo, User} - alias Pleroma.Web.Push.Subscription + alias Pleroma.Web.Push.Impl require Logger - import Ecto.Query - - @types ["Create", "Follow", "Announce", "Like"] - @gcm_api_key nil + ############## + # Client API # + ############## - def start_link() do + def start_link do GenServer.start_link(__MODULE__, :ok, name: __MODULE__) end - def init(:ok) do - case Application.get_env(:web_push_encryption, :vapid_details) do - nil -> - Logger.warn( - "VAPID key pair is not found. Please, add VAPID configuration to config. Run `mix web_push.gen.keypair` mix task to create a key pair" - ) - - :ignore - - _ -> - {:ok, %{}} - end + def vapid_config do + Application.get_env(:web_push_encryption, :vapid_details, []) end - def send(notification) do - if Application.get_env(:web_push_encryption, :vapid_details) do - GenServer.cast(Pleroma.Web.Push, {:send, notification}) + def enabled do + case vapid_config() do + [] -> false + list when is_list(list) -> true + _ -> false end end - def handle_cast( - {:send, %{activity: %{data: %{"type" => type}}, user_id: user_id} = notification}, - state - ) - when type in @types do - actor = User.get_cached_by_ap_id(notification.activity.data["actor"]) - - Subscription - |> where(user_id: ^user_id) - |> preload(:token) - |> Repo.all() - |> Enum.each(fn record -> - subscription = %{ - keys: %{ - p256dh: record.key_p256dh, - auth: record.key_auth - }, - endpoint: record.endpoint - } - - body = - Jason.encode!(%{ - title: format_title(notification), - access_token: record.token.token, - body: format_body(notification, actor), - notification_id: notification.id, - notification_type: format_type(notification), - icon: User.avatar_url(actor), - preferred_locale: "en" - }) - - case WebPushEncryption.send_web_push(body, subscription) do - {:ok, %{status_code: code}} when 400 <= code and code < 500 -> - Logger.debug("Removing subscription record") - Repo.delete!(record) - :ok + def send(notification), + do: GenServer.cast(__MODULE__, {:send, notification}) - {:ok, %{status_code: code}} when 200 <= code and code < 300 -> - :ok + #################### + # Server Callbacks # + #################### - {:ok, %{status_code: code}} -> - Logger.error("Web Push Nonification failed with code: #{code}") - :error + @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 - _ -> - Logger.error("Web Push Nonification failed with unknown error") - :error - end - end) + mix web_push.gen.keypair - {:noreply, state} - end + and add the resulting output to your configuration file. + """) - def handle_cast({:send, _}, state) do - Logger.warn("Unknown notification type") - {:noreply, state} - end - - # https://github.com/tootsuite/mastodon/blob/master/app/models/notification.rb#L19 - defp format_type(%{activity: %{data: %{"type" => type}}}) do - case type do - "Create" -> "mention" - "Follow" -> "follow" - "Announce" -> "reblog" - "Favorite" -> "favourite" + :ignore end end - defp format_title(%{activity: %{data: %{"type" => type}}}) do - case type do - "Create" -> "New Mention" - "Follow" -> "New Follower" - "Announce" -> "New Repeat" - "Like" -> "New Favorite" + @impl true + def handle_cast({:send, notification}, state) do + if enabled() do + Impl.perform_send(notification) end - end - defp format_body(%{activity: %{data: %{"type" => type}}}, actor) do - case type do - "Create" -> "@#{actor.nickname} has mentiond you" - "Follow" -> "@#{actor.nickname} has followed you" - "Announce" -> "@#{actor.nickname} has repeated your post" - "Like" -> "@#{actor.nickname} has favorited your post" - end + {:noreply, state} end end