forked from AkkomaGang/akkoma
Merge branch '1865-media-only' into 'develop'
Resolve "/api/v1/accounts/:id/statuses?only_media=true returns media that is not owned" Closes #1865 See merge request pleroma/pleroma!2650
This commit is contained in:
commit
c75ba63bef
3 changed files with 12 additions and 2 deletions
|
@ -8,6 +8,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
|
||||||
### Changed
|
### Changed
|
||||||
- **Breaking:** Elixir >=1.9 is now required (was >= 1.8)
|
- **Breaking:** Elixir >=1.9 is now required (was >= 1.8)
|
||||||
- In Conversations, return only direct messages as `last_status`
|
- In Conversations, return only direct messages as `last_status`
|
||||||
|
- Using the `only_media` filter on timelines will now exclude reblog media
|
||||||
- MFR policy to set global expiration for all local Create activities
|
- MFR policy to set global expiration for all local Create activities
|
||||||
- OGP rich media parser merged with TwitterCard
|
- OGP rich media parser merged with TwitterCard
|
||||||
<details>
|
<details>
|
||||||
|
|
|
@ -834,7 +834,8 @@ defp restrict_media(_query, %{only_media: _val, skip_preload: true}) do
|
||||||
|
|
||||||
defp restrict_media(query, %{only_media: true}) do
|
defp restrict_media(query, %{only_media: true}) do
|
||||||
from(
|
from(
|
||||||
[_activity, object] in query,
|
[activity, object] in query,
|
||||||
|
where: fragment("(?)->>'type' = ?", activity.data, "Create"),
|
||||||
where: fragment("not (?)->'attachment' = (?)", object.data, ^[])
|
where: fragment("not (?)->'attachment' = (?)", object.data, ^[])
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
|
@ -350,9 +350,10 @@ test "unimplemented pinned statuses feature", %{conn: conn} do
|
||||||
assert json_response_and_validate_schema(conn, 200) == []
|
assert json_response_and_validate_schema(conn, 200) == []
|
||||||
end
|
end
|
||||||
|
|
||||||
test "gets an users media", %{conn: conn} do
|
test "gets an users media, excludes reblogs", %{conn: conn} do
|
||||||
note = insert(:note_activity)
|
note = insert(:note_activity)
|
||||||
user = User.get_cached_by_ap_id(note.data["actor"])
|
user = User.get_cached_by_ap_id(note.data["actor"])
|
||||||
|
other_user = insert(:user)
|
||||||
|
|
||||||
file = %Plug.Upload{
|
file = %Plug.Upload{
|
||||||
content_type: "image/jpg",
|
content_type: "image/jpg",
|
||||||
|
@ -364,6 +365,13 @@ test "gets an users media", %{conn: conn} do
|
||||||
|
|
||||||
{:ok, %{id: image_post_id}} = CommonAPI.post(user, %{status: "cofe", media_ids: [media_id]})
|
{:ok, %{id: image_post_id}} = CommonAPI.post(user, %{status: "cofe", media_ids: [media_id]})
|
||||||
|
|
||||||
|
{:ok, %{id: media_id}} = ActivityPub.upload(file, actor: other_user.ap_id)
|
||||||
|
|
||||||
|
{:ok, %{id: other_image_post_id}} =
|
||||||
|
CommonAPI.post(other_user, %{status: "cofe2", media_ids: [media_id]})
|
||||||
|
|
||||||
|
{:ok, _announce} = CommonAPI.repeat(other_image_post_id, user)
|
||||||
|
|
||||||
conn = get(conn, "/api/v1/accounts/#{user.id}/statuses?only_media=true")
|
conn = get(conn, "/api/v1/accounts/#{user.id}/statuses?only_media=true")
|
||||||
|
|
||||||
assert [%{"id" => ^image_post_id}] = json_response_and_validate_schema(conn, 200)
|
assert [%{"id" => ^image_post_id}] = json_response_and_validate_schema(conn, 200)
|
||||||
|
|
Loading…
Reference in a new issue