From 6535fe93da0111942eb44ac59f7d1e9f7e86a1fb Mon Sep 17 00:00:00 2001 From: Gunjan Chhablani Date: Thu, 25 Apr 2024 13:16:35 -0400 Subject: [PATCH] [Backend] Add submissions metrics by PK (#4353) --- apps/challenges/urls.py | 5 +++++ apps/challenges/views.py | 24 ++++++++++++++++++++++++ 2 files changed, 29 insertions(+) diff --git a/apps/challenges/urls.py b/apps/challenges/urls.py index 31879dda5d..00c24e688a 100644 --- a/apps/challenges/urls.py +++ b/apps/challenges/urls.py @@ -49,6 +49,11 @@ views.get_all_challenges_submission_metrics, name="get_all_challenges_submission_metrics", ), + url( + r"^challenge/get_submission_metrics_by_pk/(?P[0-9]+)/$", + views.get_challenge_submission_metrics_by_pk, + name="get_challenge_submission_metrics_by_pk", + ), url( r"^challenges/participated/(?P[A-Za-z]+)/$", views.get_all_participated_challenges, diff --git a/apps/challenges/views.py b/apps/challenges/views.py index 664375b7ca..b79e2fae41 100644 --- a/apps/challenges/views.py +++ b/apps/challenges/views.py @@ -753,6 +753,30 @@ def get_all_challenges_submission_metrics(request): return Response(submission_metrics, status=status.HTTP_200_OK) +@api_view(["GET"]) +@throttle_classes([AnonRateThrottle]) +def get_challenge_submission_metrics_by_pk(request, pk): + """ + Returns the submission metrics for a given challenge by primary key and their phases + """ + if not is_user_a_staff(request.user): + response_data = {"error": "Sorry, you are not authorized to make this request"} + return Response(response_data, status=status.HTTP_403_FORBIDDEN) + challenge = get_challenge_model(pk) + challenge_phases = ChallengePhase.objects.filter(challenge=challenge) + submission_metrics = {} + + submission_statuses = [status[0] for status in Submission.STATUS_OPTIONS] + + # Fetch challenge phases for the challenge + challenge_phases = ChallengePhase.objects.filter(challenge=challenge) + for submission_status in submission_statuses: + count = Submission.objects.filter(challenge_phase__in=challenge_phases, status=submission_status).count() + submission_metrics[submission_status] = count + + return Response(submission_metrics, status=status.HTTP_200_OK) + + @api_view(["GET"]) @throttle_classes([AnonRateThrottle]) def get_featured_challenges(request):