Skip to content

Commit

Permalink
Merge pull request #1988 from gtech-mulearn/dev
Browse files Browse the repository at this point in the history
launchpad queryset
  • Loading branch information
jelanmathewjames authored Jun 1, 2024
2 parents 7251db9 + 88159a7 commit 8c20cf3
Showing 1 changed file with 69 additions and 64 deletions.
133 changes: 69 additions & 64 deletions api/launchpad/launchpad_views.py
Original file line number Diff line number Diff line change
@@ -1,76 +1,81 @@
from django.db.models import Sum, Max, Prefetch, When, Case, IntegerField, F
from django.db import connection
from django.db.models import (
Sum,
Max,
Prefetch,
When,
Case,
IntegerField,
F,
OuterRef,
Subquery,
)
from django.db.models.functions import Coalesce

from rest_framework.views import APIView

from .serializers import LaunchpadLeaderBoardSerializer
from utils.response import CustomResponse
from utils.utils import CommonUtils
from db.user import User
from db.organization import Organization
from db.organization import Organization, District, State
from db.task import KarmaActivityLog


class Leaderboard(APIView):
def get(self, request):
query = """
SELECT
u.full_name,
SUM(kal.karma) AS karma,
COALESCE(org.title, comm.title) AS org,
COALESCE(org.dis, d.name) AS district,
COALESCE(org.state, s.name) AS state,
MAX(kal.created_at) AS time_
FROM karma_activity_log AS kal
INNER JOIN user AS u ON kal.user_id = u.id
INNER JOIN task_list AS tl ON tl.id = kal.task_id
LEFT JOIN (
SELECT
uol.user_id,
org.id,
org.title AS title,
d.name dis,
s.name state
FROM user_organization_link AS uol
INNER JOIN organization AS org ON org.id = uol.org_id AND org.org_type IN
("College", "School", "Company")
LEFT JOIN district AS d ON d.id = org.district_id
LEFT JOIN zone AS z ON z.id = d.zone_id
LEFT JOIN state AS s ON s.id = z.state_id
GROUP BY uol.user_id
) AS org ON org.user_id = u.id
LEFT JOIN (
SELECT
uol.user_id,
org.id,
org.title AS title
FROM organization AS org
INNER JOIN user_organization_link AS uol ON org.id = uol.org_id AND org.org_type IN ("Community")
GROUP BY uol.user_id
) AS comm ON comm.user_id = u.id
LEFT JOIN district AS d ON d.id = u.district_id
LEFT JOIN zone AS z ON d.zone_id = z.id
LEFT JOIN state AS s ON z.state_id = s.id
WHERE
tl.event = "launchpad" AND
kal.appraiser_approved = TRUE AND
u.id IN (
SELECT karma_activity_log.user_id FROM karma_activity_log
INNER JOIN task_list ON karma_activity_log.task_id = task_list.id
WHERE
task_list.hashtag = "#lp24-introduction" AND
karma_activity_log.appraiser_approved = TRUE
karma_subquery = (
KarmaActivityLog.objects.filter(
user=OuterRef("id"),
task__event="launchpad",
appraiser_approved=True,
task__hashtag="#lp24-introduction",
)
GROUP BY u.id
ORDER BY karma DESC, time_
"""
with connection.cursor() as cursor:
cursor.execute(query)
results = cursor.fetchall()
column_names = [desc[0] for desc in cursor.description]
user_ids = set()
list_of_dicts = []
for row in results:
if row[0] not in user_ids:
user_ids.add(row[0])
list_of_dicts.append(dict(zip(column_names, row)))
return CustomResponse(response=list_of_dicts).get_success_response()
.annotate(total_karma=Sum("karma"))
.values("total_karma")
)
users = (
User.objects.filter(
karma_activity_log_user__task__event="launchpad",
karma_activity_log_user__appraiser_approved=True,
karma_activity_log_user__task__hashtag="#lp24-introduction",
)
.prefetch_related(
Prefetch(
"user_organization_link_user__org",
queryset=Organization.objects.filter(
org_type__in=["College", "School", "Company"]
)
.select_related("district", "district_zone_state_name")
.all(),
)
)
.annotate(
karma=Subquery(karma_subquery, output_field=IntegerField()),
time_=Max("karma_activity_log_user__created_at"),
org=F("user_organization_link_user__org__title"),
district_name=F("district__name"),
state=F("district__zone__state__name"),
)
.values("full_name", "karma", "org", "district_name", "state", "time_")
.order_by("-karma", "time_")
)

paginated_queryset = CommonUtils.get_paginated_queryset(
users,
request,
["karma", "org", "district_name", "state", "time_"],
sort_fields={
"karma": "karma",
"org": "org",
"district_name": "district_name",
"state": "state",
"time_": "time_",
},
)

serializer = LaunchpadLeaderBoardSerializer(
paginated_queryset.get("queryset"), many=True
)
return CustomResponse().paginated_response(
data=serializer.data, pagination=paginated_queryset.get("pagination")
)

0 comments on commit 8c20cf3

Please sign in to comment.