Browse Source

Add `with_move` query param to the notifications API

feature/compile_get
Egor Kislitsyn 4 years ago
parent
commit
624e720aa4
6 changed files with 49 additions and 9 deletions
  1. +9
    -0
      lib/pleroma/notification.ex
  2. +2
    -1
      lib/pleroma/web/mastodon_api/mastodon_api.ex
  3. +6
    -2
      test/notification_test.exs
  4. +2
    -2
      test/web/activity_pub/activity_pub_test.exs
  5. +26
    -0
      test/web/mastodon_api/controllers/notification_controller_test.exs
  6. +4
    -4
      test/web/mastodon_api/views/notification_view_test.exs

+ 9
- 0
lib/pleroma/notification.ex View File

@@ -57,6 +57,7 @@ defmodule Pleroma.Notification do
|> exclude_muted(user, opts)
|> exclude_blocked(user)
|> exclude_visibility(opts)
|> exclude_move(opts)
end

defp exclude_blocked(query, user) do
@@ -81,6 +82,14 @@ defmodule Pleroma.Notification do
|> where([n, a, o, tm], is_nil(tm.user_id))
end

defp exclude_move(query, %{with_move: true}) do
query
end

defp exclude_move(query, _opts) do
where(query, [n, a], fragment("?->>'type' != 'Move'", a.data))
end

@valid_visibilities ~w[direct unlisted public private]

defp exclude_visibility(query, %{exclude_visibilities: visibility})


+ 2
- 1
lib/pleroma/web/mastodon_api/mastodon_api.ex View File

@@ -73,7 +73,8 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPI do
exclude_types: {:array, :string},
exclude_visibilities: {:array, :string},
reblogs: :boolean,
with_muted: :boolean
with_muted: :boolean,
with_move: :boolean
}

changeset = cast({%{}, param_types}, params, Map.keys(param_types))


+ 6
- 2
test/notification_test.exs View File

@@ -643,13 +643,17 @@ defmodule Pleroma.NotificationTest do
Pleroma.Web.ActivityPub.ActivityPub.move(old_user, new_user)
ObanHelpers.perform_all()

assert [] = Notification.for_user(follower)

assert [
%{
activity: %{
data: %{"type" => "Move", "actor" => ^old_ap_id, "target" => ^new_ap_id}
}
}
] = Notification.for_user(follower)
] = Notification.for_user(follower, %{with_move: true})

assert [] = Notification.for_user(other_follower)

assert [
%{
@@ -657,7 +661,7 @@ defmodule Pleroma.NotificationTest do
data: %{"type" => "Move", "actor" => ^old_ap_id, "target" => ^new_ap_id}
}
}
] = Notification.for_user(other_follower)
] = Notification.for_user(other_follower, %{with_move: true})
end
end



+ 2
- 2
test/web/activity_pub/activity_pub_test.exs View File

@@ -1619,10 +1619,10 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do
activity = %Activity{activity | object: nil}

assert [%Notification{activity: ^activity}] =
Notification.for_user_since(follower, ~N[2019-04-13 11:22:33])
Notification.for_user(follower, %{with_move: true})

assert [%Notification{activity: ^activity}] =
Notification.for_user_since(follower_move_opted_out, ~N[2019-04-13 11:22:33])
Notification.for_user(follower_move_opted_out, %{with_move: true})
end

test "old user must be in the new user's `also_known_as` list" do


+ 26
- 0
test/web/mastodon_api/controllers/notification_controller_test.exs View File

@@ -341,6 +341,32 @@ defmodule Pleroma.Web.MastodonAPI.NotificationControllerTest do
assert length(json_response(conn, 200)) == 1
end

test "see move notifications with `with_move` parameter", %{
conn: conn
} do
old_user = insert(:user)
new_user = insert(:user, also_known_as: [old_user.ap_id])
follower = insert(:user)

User.follow(follower, old_user)
Pleroma.Web.ActivityPub.ActivityPub.move(old_user, new_user)
Pleroma.Tests.ObanHelpers.perform_all()

conn =
conn
|> assign(:user, follower)
|> get("/api/v1/notifications")

assert json_response(conn, 200) == []

conn =
build_conn()
|> assign(:user, follower)
|> get("/api/v1/notifications", %{"with_move" => "true"})

assert length(json_response(conn, 200)) == 1
end

defp get_notification_id_by_activity(%{id: id}) do
Notification
|> Repo.get_by(activity_id: id)


+ 4
- 4
test/web/mastodon_api/views/notification_view_test.exs View File

@@ -109,22 +109,22 @@ defmodule Pleroma.Web.MastodonAPI.NotificationViewTest do
end

test "Move notification" do
%{ap_id: old_ap_id} = old_user = insert(:user)
%{ap_id: _new_ap_id} = new_user = insert(:user, also_known_as: [old_ap_id])
old_user = insert(:user)
new_user = insert(:user, also_known_as: [old_user.ap_id])
follower = insert(:user)

User.follow(follower, old_user)
Pleroma.Web.ActivityPub.ActivityPub.move(old_user, new_user)
Pleroma.Tests.ObanHelpers.perform_all()

[notification] = Notification.for_user(follower)
[notification] = Notification.for_user(follower, %{with_move: true})

expected = %{
id: to_string(notification.id),
pleroma: %{is_seen: false},
type: "move",
account: AccountView.render("show.json", %{user: old_user, for: follower}),
target: AccountView.render("show.json", %{user: new_user, for: follower}),
target: AccountView.render("show.json", %{user: refresh_record(new_user), for: follower}),
created_at: Utils.to_masto_date(notification.inserted_at)
}



Loading…
Cancel
Save