]> git.openstreetmap.org Git - osqa.git/blobdiff - forum/badges/base.py
Kill that annoying problem that when users without a valid email at register time...
[osqa.git] / forum / badges / base.py
index fce6b6e30301c542a585f76ba8e2bd799eabb9fc..3af46f7c20496c0ac101e9af9658343f0528f571 100644 (file)
@@ -4,7 +4,7 @@ from string import lower
 from django.contrib.contenttypes.models import ContentType
 from django.db.models.signals import post_save
 
-from forum.models import Badge, Node
+from forum.models import Badge, Node, Action
 from forum.actions import AwardAction
 
 import logging
@@ -60,10 +60,12 @@ class AbstractBadge(object):
     def award(cls, user, action, once=False):
         if once:
             node = None
+            awarded = AwardAction.get_for(user, cls.ondb)
         else:
             node = action.node
+            awarded = AwardAction.get_for(user, cls.ondb, node)
 
-        awarded = AwardAction.get_for(user, node, cls.ondb)
+        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=action))
\ No newline at end of file
+            AwardAction(user=user, node=node, ip=action.ip).save(data=dict(badge=cls.ondb, trigger=trigger))
\ No newline at end of file