Mercurial > public > sg101
view bio/badges.py @ 948:f2fbe2b0d25d
Use unicode to log messages.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sat, 16 May 2015 15:02:04 -0500 |
parents | 5892c05886a9 |
children |
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, POTD_PIN, MAP_PIN) = range(8) 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.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() logging.info('Awarded %s with the badge: %s', user.username, badge.name)