X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/2cc0aa8a5d5c3b84c59598092c289d39b0cc4d3c..9a07d715b9bc321ff7aa957c9768f7dff07d6c02:/forum/badges/base.py diff --git a/forum/badges/base.py b/forum/badges/base.py index 1900119..c78a925 100644 --- a/forum/badges/base.py +++ b/forum/badges/base.py @@ -20,10 +20,12 @@ class BadgesMeta(type): if not dic.get('abstract', False): if not name in installed: - badge.ondb = Badge(cls=name, type=dic.get('type', Badge.BRONZE)) - badge.ondb.save() + ondb = Badge(cls=name, type=dic.get('type', Badge.BRONZE)) + ondb.save() else: - badge.ondb = installed[name] + ondb = installed[name] + + badge.ondb = ondb.id inst = badge() @@ -36,9 +38,8 @@ class BadgesMeta(type): for action in badge.listen_to: action.hook(hook) - BadgesMeta.by_class[name] = badge - badge.ondb.__dict__['_class'] = inst - BadgesMeta.by_id[badge.ondb.id] = badge + BadgesMeta.by_class[name] = inst + BadgesMeta.by_id[ondb.id] = inst return badge @@ -58,18 +59,19 @@ class AbstractBadge(object): @classmethod def award(cls, user, action, once=False): + db_object = Badge.objects.get(id=cls.ondb) try: if once: node = None - awarded = AwardAction.get_for(user, cls.ondb) + awarded = AwardAction.get_for(user, db_object) else: node = action.node - awarded = AwardAction.get_for(user, cls.ondb, node) + awarded = AwardAction.get_for(user, db_object, node) trigger = isinstance(action, Action) and action or None if not awarded: - AwardAction(user=user, node=node, ip=action.ip).save(data=dict(badge=cls.ondb, trigger=trigger)) + AwardAction(user=user, node=node).save(data=dict(badge=db_object, trigger=trigger)) except MultipleObjectsReturned: if node: logging.error('Found multiple %s badges awarded for user %s (%s)' % (self.name, user.username, user.id))