Mercurial > public > sg101
view gpp/bio/badges.py @ 388:c3231af55778
For #191; r410 is wrong: it is returning the wrong posts. Rework. MySQL is not using an index on our query, and it is taking 10+ seconds. Replace this slow query with a loop that loops over the public forums, then sorts and returns the posts.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sat, 19 Mar 2011 05:03:51 +0000 |
parents | 767cedc7d12a |
children | 47f4259ce511 |
line wrap: on
line source
"""This module contains user profile badge-related functionality.""" import logging from bio.models import Badge from bio.models import BadgeOwnership # Numeric ID's for badges that are awarded for user actions: (CONTRIBUTOR_PIN, CALENDAR_PIN, NEWS_PIN, LINK_PIN, DOWNLOAD_PIN, SECURITY_PIN) = range(6) def award_badge(badge_id, user): """This function awards the badge specified by badge_id to the given user. If the user already has the badge, the badge count is incremented by one. """ try: badge = Badge.objects.get(numeric_id=badge_id) except Badge.DoesNotExist: logging.error("Can't award badge with numeric_id = %d", badge_id) return profile = user.get_profile() # Does the user already have badges of this type? try: bo = BadgeOwnership.objects.get(profile=profile, badge=badge) except BadgeOwnership.DoesNotExist: # No badge of this type, yet bo = BadgeOwnership(profile=profile, badge=badge, count=1) else: # Already have this badge bo.count += 1 bo.save()