add leaderboard

This commit is contained in:
2026-03-09 20:00:06 +08:00
parent c01273bccd
commit 3a58925764
9 changed files with 104 additions and 4 deletions

View File

@@ -10,6 +10,7 @@ from django.db.models import OuterRef, Subquery, IntegerField
from .schemas import (
FlagIn,
MyScoreOut,
SubmissionFilter,
SubmissionIn,
SubmissionOut,
@@ -81,6 +82,28 @@ def list_submissions(request, filters: SubmissionFilter = Query(...)):
return submissions
@router.get("/my-scores", response=List[MyScoreOut])
@login_required
def my_scores(request):
seen = {}
for s in Submission.objects.filter(
user=request.user, task__task_type="challenge"
).order_by("-score").select_related("task"):
if s.task_id not in seen:
seen[s.task_id] = s
return [
MyScoreOut(
task_id=s.task_id,
task_display=s.task.display,
task_title=s.task.title,
score=s.score,
created=s.created.isoformat(),
)
for s in seen.values()
]
@router.get("/{submission_id}", response=SubmissionOut)
@login_required
def get_submission(request, submission_id: UUID):

View File

@@ -136,3 +136,4 @@ def update_submission_score_on_save(sender, instance, **kwargs):
当Rating保存时更新对应的Submission的平均分
"""
instance.submission.update_score()
instance.submission.user.profile.recalculate_total_score()

View File

@@ -105,3 +105,11 @@ class SubmissionFilter(Schema):
class FlagIn(Schema):
flag: Optional[Literal["red", "blue", "green", "yellow"]] = None
class MyScoreOut(Schema):
task_id: int
task_display: int
task_title: str
score: float
created: str