Merge branch 'optimize-followed-hashtags' into 'develop'

Optimize followed hashtag ids query

See merge request pleroma/pleroma!4333
This commit is contained in:
mkljczk 2025-03-24 11:12:27 +00:00
commit 0de0b0f7ef
4 changed files with 15 additions and 17 deletions

View file

@ -0,0 +1 @@
Optimize followed hashtag ids query

View file

@ -928,15 +928,9 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do
# that reference a hashtag that the user follows
# Firstly, two fallbacks in case there's no hashtag constraint, or the user doesn't
# follow any
defp restrict_recipients_or_hashtags(query, recipients, user, nil) do
restrict_recipients(query, recipients, user)
end
defp restrict_recipients_or_hashtags(query, recipients, user, true) do
followed_hashtag_ids = Ecto.assoc(user, :followed_hashtags) |> select([h], h.id)
defp restrict_recipients_or_hashtags(query, recipients, user, []) do
restrict_recipients(query, recipients, user)
end
defp restrict_recipients_or_hashtags(query, recipients, _user, hashtag_ids) do
from([activity, object] in query)
|> join(:left, [activity, object], hto in "hashtags_objects",
on: hto.object_id == object.id,
@ -944,11 +938,16 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do
)
|> where(
[activity, object, hto: hto],
(hto.hashtag_id in ^hashtag_ids and ^Constants.as_public() in activity.recipients) or
(hto.hashtag_id in subquery(followed_hashtag_ids) and
^Constants.as_public() in activity.recipients) or
fragment("? && ?", ^recipients, activity.recipients)
)
end
defp restrict_recipients_or_hashtags(query, recipients, user, _) do
restrict_recipients(query, recipients, user)
end
defp restrict_local(query, %{local_only: true}) do
from(activity in query, where: activity.local == true)
end
@ -1439,7 +1438,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do
|> maybe_preload_report_notes(opts)
|> maybe_set_thread_muted_field(opts)
|> maybe_order(opts)
|> restrict_recipients_or_hashtags(recipients, opts[:user], opts[:followed_hashtags])
|> restrict_recipients_or_hashtags(recipients, opts[:user], opts[:with_followed_hashtags])
|> restrict_replies(opts)
|> restrict_since(opts)
|> restrict_local(opts)

View file

@ -40,11 +40,6 @@ defmodule Pleroma.Web.MastodonAPI.TimelineController do
# GET /api/v1/timelines/home
def home(%{assigns: %{user: user}} = conn, params) do
followed_hashtags =
user
|> User.followed_hashtags()
|> Enum.map(& &1.id)
params =
params
|> Map.put(:type, ["Create", "Announce"])
@ -54,7 +49,7 @@ defmodule Pleroma.Web.MastodonAPI.TimelineController do
|> Map.put(:announce_filtering_user, user)
|> Map.put(:user, user)
|> Map.put(:local_only, params[:local])
|> Map.put(:followed_hashtags, followed_hashtags)
|> Map.put(:with_followed_hashtags, true)
|> Map.delete(:local)
activities =

View file

@ -873,6 +873,8 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do
user = insert(:user)
other_user = insert(:user)
{:ok, other_user} = User.follow_hashtag(other_user, hashtag)
{:ok, normally_visible} =
CommonAPI.post(other_user, %{status: "hello :)", visibility: "public"})
@ -883,7 +885,8 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do
activities =
ActivityPub.fetch_activities([other_user.follower_address], %{
followed_hashtags: [hashtag.id]
user: other_user,
with_followed_hashtags: true
})
assert length(activities) == 3