mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-11 01:35:28 +00:00
Optimize HomeStream.get_audience
This splits HomeStream.get_audience into two separate database queries, in order to more effectively take advantage of the indexes we have. Combining the user ID query and the user following query means that Postgres isn't able to use the index we have on the userfollows table. The query planner claims that the userfollows query should be about 20 times faster than it was previously, and the id query should take a negligible amount of time, since it's selecting a single item by primary key. We don't need to worry about duplicates, since there is a constraint preventing a user from following themself. Fixes: #2720
This commit is contained in:
parent
23698dafe5
commit
56243f6529
1 changed files with 6 additions and 5 deletions
|
@ -160,14 +160,15 @@ class HomeStream(ActivityStream):
|
||||||
|
|
||||||
key = "home"
|
key = "home"
|
||||||
|
|
||||||
def _get_audience(self, status):
|
def get_audience(self, status):
|
||||||
audience = super()._get_audience(status)
|
audience = super()._get_audience(status)
|
||||||
if not audience:
|
if not audience:
|
||||||
return []
|
return []
|
||||||
return audience.filter(
|
# if the user is the post's author
|
||||||
Q(id=status.user.id) # if the user is the post's author
|
ids_self = [user.id for user in audience.filter(Q(id=status.user.id))]
|
||||||
| Q(following=status.user) # if the user is following the author
|
# if the user is following the author
|
||||||
).distinct()
|
ids_following = [user.id for user in audience.filter(Q(following=status.user))]
|
||||||
|
return ids_self + ids_following
|
||||||
|
|
||||||
def get_statuses_for_user(self, user):
|
def get_statuses_for_user(self, user):
|
||||||
return models.Status.privacy_filter(
|
return models.Status.privacy_filter(
|
||||||
|
|
Loading…
Reference in a new issue