mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-25 08:28:09 +00:00
Merge branch 'follow-request-notifications' into 'develop'
Follow request notifications enforcement See merge request pleroma/pleroma!2451
This commit is contained in:
parent
7b05933677
commit
c75840f7b8
4 changed files with 11 additions and 44 deletions
|
@ -581,8 +581,6 @@ config :pleroma, :email_notifications,
|
||||||
inactivity_threshold: 7
|
inactivity_threshold: 7
|
||||||
}
|
}
|
||||||
|
|
||||||
config :pleroma, :notifications, enable_follow_request_notifications: false
|
|
||||||
|
|
||||||
config :pleroma, :oauth2,
|
config :pleroma, :oauth2,
|
||||||
token_expires_in: 600,
|
token_expires_in: 600,
|
||||||
issue_new_refresh_token: true,
|
issue_new_refresh_token: true,
|
||||||
|
|
|
@ -2286,20 +2286,6 @@ config :pleroma, :config_description, [
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
%{
|
|
||||||
group: :pleroma,
|
|
||||||
key: :notifications,
|
|
||||||
type: :group,
|
|
||||||
description: "Notification settings",
|
|
||||||
children: [
|
|
||||||
%{
|
|
||||||
key: :enable_follow_request_notifications,
|
|
||||||
type: :boolean,
|
|
||||||
description:
|
|
||||||
"Enables notifications on new follow requests (causes issues with older PleromaFE versions)."
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
%{
|
%{
|
||||||
group: :pleroma,
|
group: :pleroma,
|
||||||
key: Pleroma.Emails.UserEmail,
|
key: Pleroma.Emails.UserEmail,
|
||||||
|
|
|
@ -293,17 +293,8 @@ defmodule Pleroma.Notification do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_notifications(%Activity{data: %{"type" => "Follow"}} = activity) do
|
|
||||||
if Pleroma.Config.get([:notifications, :enable_follow_request_notifications]) ||
|
|
||||||
Activity.follow_accepted?(activity) do
|
|
||||||
do_create_notifications(activity)
|
|
||||||
else
|
|
||||||
{:ok, []}
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def create_notifications(%Activity{data: %{"type" => type}} = activity)
|
def create_notifications(%Activity{data: %{"type" => type}} = activity)
|
||||||
when type in ["Like", "Announce", "Move", "EmojiReact"] do
|
when type in ["Follow", "Like", "Announce", "Move", "EmojiReact"] do
|
||||||
do_create_notifications(activity)
|
do_create_notifications(activity)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -312,9 +312,7 @@ defmodule Pleroma.NotificationTest do
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
test "if `follow_request` notifications are enabled, " <>
|
test "it creates `follow_request` notification for pending Follow activity" do
|
||||||
"it creates `follow_request` notification for pending Follow activity" do
|
|
||||||
clear_config([:notifications, :enable_follow_request_notifications], true)
|
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
followed_user = insert(:user, locked: true)
|
followed_user = insert(:user, locked: true)
|
||||||
|
|
||||||
|
@ -333,21 +331,6 @@ defmodule Pleroma.NotificationTest do
|
||||||
assert %{type: "follow"} = NotificationView.render("show.json", render_opts)
|
assert %{type: "follow"} = NotificationView.render("show.json", render_opts)
|
||||||
end
|
end
|
||||||
|
|
||||||
test "if `follow_request` notifications are disabled, " <>
|
|
||||||
"it does NOT create `follow*` notification for pending Follow activity" do
|
|
||||||
clear_config([:notifications, :enable_follow_request_notifications], false)
|
|
||||||
user = insert(:user)
|
|
||||||
followed_user = insert(:user, locked: true)
|
|
||||||
|
|
||||||
{:ok, _, _, _activity} = CommonAPI.follow(user, followed_user)
|
|
||||||
refute FollowingRelationship.following?(user, followed_user)
|
|
||||||
assert [] = Notification.for_user(followed_user)
|
|
||||||
|
|
||||||
# After request is accepted, no new notifications are generated:
|
|
||||||
assert {:ok, _} = CommonAPI.accept_follow_request(user, followed_user)
|
|
||||||
assert [] = Notification.for_user(followed_user)
|
|
||||||
end
|
|
||||||
|
|
||||||
test "it doesn't create a notification for follow-unfollow-follow chains" do
|
test "it doesn't create a notification for follow-unfollow-follow chains" do
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
followed_user = insert(:user, locked: false)
|
followed_user = insert(:user, locked: false)
|
||||||
|
@ -362,6 +345,15 @@ defmodule Pleroma.NotificationTest do
|
||||||
notification_id = notification.id
|
notification_id = notification.id
|
||||||
assert [%{id: ^notification_id}] = Notification.for_user(followed_user)
|
assert [%{id: ^notification_id}] = Notification.for_user(followed_user)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "dismisses the notification on follow request rejection" do
|
||||||
|
user = insert(:user, locked: true)
|
||||||
|
follower = insert(:user)
|
||||||
|
{:ok, _, _, _follow_activity} = CommonAPI.follow(follower, user)
|
||||||
|
assert [notification] = Notification.for_user(user)
|
||||||
|
{:ok, _follower} = CommonAPI.reject_follow_request(follower, user)
|
||||||
|
assert [] = Notification.for_user(user)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "get notification" do
|
describe "get notification" do
|
||||||
|
|
Loading…
Reference in a new issue