2018-03-25 15:24:08 +00:00
|
|
|
from django.db import models
|
|
|
|
|
|
|
|
from funkwhale_api.common import fields
|
|
|
|
from funkwhale_api.favorites.models import TrackFavorite
|
|
|
|
from funkwhale_api.history.models import Listening
|
|
|
|
|
|
|
|
|
|
|
|
def combined_recent(limit, **kwargs):
|
2018-06-09 13:36:16 +00:00
|
|
|
datetime_field = kwargs.pop("datetime_field", "creation_date")
|
|
|
|
source_querysets = {qs.model._meta.label: qs for qs in kwargs.pop("querysets")}
|
2018-03-25 15:24:08 +00:00
|
|
|
querysets = {
|
|
|
|
k: qs.annotate(
|
2018-06-09 13:36:16 +00:00
|
|
|
__type=models.Value(qs.model._meta.label, output_field=models.CharField())
|
|
|
|
).values("pk", datetime_field, "__type")
|
2018-03-25 15:24:08 +00:00
|
|
|
for k, qs in source_querysets.items()
|
|
|
|
}
|
|
|
|
_qs_list = list(querysets.values())
|
|
|
|
union_qs = _qs_list[0].union(*_qs_list[1:])
|
|
|
|
records = []
|
2018-06-09 13:36:16 +00:00
|
|
|
for row in union_qs.order_by("-{}".format(datetime_field))[:limit]:
|
|
|
|
records.append(
|
|
|
|
{"type": row["__type"], "when": row[datetime_field], "pk": row["pk"]}
|
|
|
|
)
|
2018-03-25 15:24:08 +00:00
|
|
|
# Now we bulk-load each object type in turn
|
|
|
|
to_load = {}
|
|
|
|
for record in records:
|
2018-06-09 13:36:16 +00:00
|
|
|
to_load.setdefault(record["type"], []).append(record["pk"])
|
2018-03-25 15:24:08 +00:00
|
|
|
fetched = {}
|
|
|
|
|
|
|
|
for key, pks in to_load.items():
|
|
|
|
for item in source_querysets[key].filter(pk__in=pks):
|
|
|
|
fetched[(key, item.pk)] = item
|
|
|
|
|
|
|
|
# Annotate 'records' with loaded objects
|
|
|
|
for record in records:
|
2018-06-09 13:36:16 +00:00
|
|
|
record["object"] = fetched[(record["type"], record["pk"])]
|
2018-03-25 15:24:08 +00:00
|
|
|
return records
|
|
|
|
|
|
|
|
|
|
|
|
def get_activity(user, limit=20):
|
2018-06-09 13:36:16 +00:00
|
|
|
query = fields.privacy_level_query(user, lookup_field="user__privacy_level")
|
2018-03-25 15:24:08 +00:00
|
|
|
querysets = [
|
|
|
|
Listening.objects.filter(query).select_related(
|
2018-06-09 13:36:16 +00:00
|
|
|
"track", "user", "track__artist", "track__album__artist"
|
2018-03-25 15:24:08 +00:00
|
|
|
),
|
|
|
|
TrackFavorite.objects.filter(query).select_related(
|
2018-06-09 13:36:16 +00:00
|
|
|
"track", "user", "track__artist", "track__album__artist"
|
2018-03-25 15:24:08 +00:00
|
|
|
),
|
|
|
|
]
|
|
|
|
records = combined_recent(limit=limit, querysets=querysets)
|
2018-06-09 13:36:16 +00:00
|
|
|
return [r["object"] for r in records]
|