Include list id in StatusView

Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
marcin mikołajczak 2024-09-03 15:17:45 +02:00
parent fecfe8bf89
commit 6d5ae4d2e9
5 changed files with 27 additions and 2 deletions

View file

@ -0,0 +1 @@
Include list id in StatusView

View file

@ -42,6 +42,7 @@ Has these additional fields under the `pleroma` object:
- `quotes_count`: the count of status quotes. - `quotes_count`: the count of status quotes.
- `non_anonymous`: true if the source post specifies the poll results are not anonymous. Currently only implemented by Smithereen. - `non_anonymous`: true if the source post specifies the poll results are not anonymous. Currently only implemented by Smithereen.
- `bookmark_folder`: the ID of the folder bookmark is stored within (if any). - `bookmark_folder`: the ID of the folder bookmark is stored within (if any).
- `list_id`: the ID of the list the post is addressed to (if any, only returned to author).
The `GET /api/v1/statuses/:id/source` endpoint additionally has the following attributes: The `GET /api/v1/statuses/:id/source` endpoint additionally has the following attributes:

View file

@ -249,6 +249,12 @@ defmodule Pleroma.Web.ApiSpec.Schemas.Status do
nullable: true, nullable: true,
description: description:
"A datetime (ISO 8601) that states when the post was pinned or `null` if the post is not pinned" "A datetime (ISO 8601) that states when the post was pinned or `null` if the post is not pinned"
},
list_id: %Schema{
type: :integer,
nullable: true,
description:
"The ID of the list the post is addressed to (if any, only returned to author)"
} }
} }
}, },

View file

@ -465,7 +465,8 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do
parent_visible: visible_for_user?(reply_to, opts[:for]), parent_visible: visible_for_user?(reply_to, opts[:for]),
pinned_at: pinned_at, pinned_at: pinned_at,
quotes_count: object.data["quotesCount"] || 0, quotes_count: object.data["quotesCount"] || 0,
bookmark_folder: bookmark_folder bookmark_folder: bookmark_folder,
list_id: get_list_id(object, client_posted_this_activity)
} }
} }
end end
@ -835,4 +836,14 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do
nil nil
end end
end end
defp get_list_id(object, client_posted_this_activity) do
with true <- client_posted_this_activity,
%{data: %{"listMessage" => list_ap_id}} when is_binary(list_ap_id) <- object,
%{id: list_id} <- Pleroma.List.get_by_ap_id(list_ap_id) do
list_id
else
_ -> nil
end
end
end end

View file

@ -342,7 +342,8 @@ defmodule Pleroma.Web.MastodonAPI.StatusViewTest do
parent_visible: false, parent_visible: false,
pinned_at: nil, pinned_at: nil,
quotes_count: 0, quotes_count: 0,
bookmark_folder: nil bookmark_folder: nil,
list_id: nil
} }
} }
@ -912,6 +913,11 @@ defmodule Pleroma.Web.MastodonAPI.StatusViewTest do
status = StatusView.render("show.json", activity: activity) status = StatusView.render("show.json", activity: activity)
assert status.visibility == "list" assert status.visibility == "list"
assert status.pleroma.list_id == nil
status = StatusView.render("show.json", activity: activity, for: user)
assert status.pleroma.list_id == list.id
end end
test "has a field for parent visibility" do test "has a field for parent visibility" do