projects
/
akkoma
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
small refactoring
[akkoma]
/
lib
/
pleroma
/
web
/
push
/
subscription.ex
diff --git
a/lib/pleroma/web/push/subscription.ex
b/lib/pleroma/web/push/subscription.ex
index da301fbbccebc2a50a5187255245437822496cd5..5b5aa0d597567fb80cf5521f66628d4e09d86fae 100644
(file)
--- a/
lib/pleroma/web/push/subscription.ex
+++ b/
lib/pleroma/web/push/subscription.ex
@@
-1,5
+1,5
@@
# Pleroma: A lightweight social networking server
# Pleroma: A lightweight social networking server
-# Copyright © 2017-20
19
Pleroma Authors <https://pleroma.social/>
+# Copyright © 2017-20
20
Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Web.Push.Subscription do
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Web.Push.Subscription do
@@
-15,7
+15,7
@@
defmodule Pleroma.Web.Push.Subscription do
@type t :: %__MODULE__{}
schema "push_subscriptions" do
@type t :: %__MODULE__{}
schema "push_subscriptions" do
- belongs_to(:user, User, type:
Pleroma.FlakeId
)
+ belongs_to(:user, User, type:
FlakeId.Ecto.CompatType
)
belongs_to(:token, Token)
field(:endpoint, :string)
field(:key_p256dh, :string)
belongs_to(:token, Token)
field(:endpoint, :string)
field(:key_p256dh, :string)
@@
-25,20
+25,28
@@
defmodule Pleroma.Web.Push.Subscription do
timestamps()
end
timestamps()
end
- @supported_alert_types ~w[follow favourite mention reblog
]
+ @supported_alert_types ~w[follow favourite mention reblog
pleroma:chat_mention]a
- defp alerts(%{
"data" => %{"alerts" =>
alerts}}) do
+ defp alerts(%{
data: %{alerts:
alerts}}) do
alerts = Map.take(alerts, @supported_alert_types)
%{"alerts" => alerts}
end
alerts = Map.take(alerts, @supported_alert_types)
%{"alerts" => alerts}
end
+ def enabled?(subscription, "follow_request") do
+ enabled?(subscription, "follow")
+ end
+
+ def enabled?(subscription, alert_type) do
+ get_in(subscription.data, ["alerts", alert_type])
+ end
+
def create(
%User{} = user,
%Token{} = token,
%{
def create(
%User{} = user,
%Token{} = token,
%{
-
"subscription" =>
%{
-
"endpoint" =>
endpoint,
-
"keys" => %{"auth" => key_auth, "p256dh" =>
key_p256dh}
+
subscription:
%{
+
endpoint:
endpoint,
+
keys: %{auth: key_auth, p256dh:
key_p256dh}
}
} = params
) do
}
} = params
) do