Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion backend/contributions/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -1050,7 +1050,9 @@ def review(self, request, pk=None):
and not hasattr(contribution_user, 'builder')):
from leaderboard.models import ensure_builder_status, update_user_leaderboard_entries
ensure_builder_status(contribution_user, submission.contribution_date)
update_user_leaderboard_entries(contribution_user)
# Re-fetch user to avoid stale reverse-relation cache from the hasattr check above
fresh_user = type(contribution_user).objects.get(pk=contribution_user.pk)
update_user_leaderboard_entries(fresh_user)

# Copy evidence items using bulk_create for better performance
Evidence.objects.bulk_create([
Expand Down
7 changes: 7 additions & 0 deletions backend/leaderboard/apps.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,10 @@
class LeaderboardConfig(AppConfig):
default_auto_field = 'django.db.models.BigAutoField'
name = 'leaderboard'

def ready(self):
from django.db.models.signals import post_save
from leaderboard.models import update_leaderboard_on_builder_creation

Builder = self.apps.get_model('builders', 'Builder')
post_save.connect(update_leaderboard_on_builder_creation, sender=Builder)
Loading