]> git.openstreetmap.org Git - osqa.git/blobdiff - forum/models/meta.py
Simple method to hold the current request for special cases.
[osqa.git] / forum / models / meta.py
old mode 100755 (executable)
new mode 100644 (file)
index 3dfd3e8..2b790d8
@@ -1,89 +1,82 @@
-from base import *\r
-\r
-class VoteManager(models.Manager):\r
-    def get_up_vote_count_from_user(self, user):\r
-        if user is not None:\r
-            return self.filter(user=user, vote=1).count()\r
-        else:\r
-            return 0\r
-\r
-    def get_down_vote_count_from_user(self, user):\r
-        if user is not None:\r
-            return self.filter(user=user, vote=-1).count()\r
-        else:\r
-            return 0\r
-\r
-    def get_votes_count_today_from_user(self, user):\r
-        if user is not None:\r
-            today = datetime.date.today()\r
-            return self.filter(user=user, voted_at__range=(today, today + datetime.timedelta(1))).count()\r
-\r
-        else:\r
-            return 0\r
-\r
-\r
-class Vote(MetaContent):\r
-    VOTE_UP = +1\r
-    VOTE_DOWN = -1\r
-    VOTE_CHOICES = (\r
-        (VOTE_UP,   u'Up'),\r
-        (VOTE_DOWN, u'Down'),\r
-    )\r
-\r
-    vote           = models.SmallIntegerField(choices=VOTE_CHOICES)\r
-    voted_at       = models.DateTimeField(default=datetime.datetime.now)\r
-\r
-    objects = VoteManager()\r
-\r
-    class Meta(MetaContent.Meta):\r
-        unique_together = ('content_type', 'object_id', 'user')\r
-        db_table = u'vote'\r
-\r
-    def __unicode__(self):\r
-        return '[%s] voted at %s: %s' %(self.user, self.voted_at, self.vote)\r
-\r
-    def is_upvote(self):\r
-        return self.vote == self.VOTE_UP\r
-\r
-    def is_downvote(self):\r
-        return self.vote == self.VOTE_DOWN\r
-\r
-\r
-class FlaggedItemManager(models.Manager):\r
-    def get_flagged_items_count_today(self, user):\r
-        if user is not None:\r
-            today = datetime.date.today()\r
-            return self.filter(user=user, flagged_at__range=(today, today + datetime.timedelta(1))).count()\r
-        else:\r
-            return 0\r
-\r
-class FlaggedItem(MetaContent):\r
-    """A flag on a Question or Answer indicating offensive content."""\r
-    flagged_at     = models.DateTimeField(default=datetime.datetime.now)\r
-\r
-    objects = FlaggedItemManager()\r
-\r
-    class Meta(MetaContent.Meta):\r
-        unique_together = ('content_type', 'object_id', 'user')\r
-        db_table = u'flagged_item'\r
-\r
-    def __unicode__(self):\r
-        return '[%s] flagged at %s' %(self.user, self.flagged_at)\r
-\r
-class Comment(MetaContent):\r
-    comment        = models.CharField(max_length=300)\r
-    added_at       = models.DateTimeField(default=datetime.datetime.now)\r
-\r
-    class Meta(MetaContent.Meta):\r
-        ordering = ('-added_at',)\r
-        db_table = u'comment'\r
-\r
-    def save(self,**kwargs):\r
-        super(Comment,self).save(**kwargs)\r
-        try:\r
-            ping_google()\r
-        except Exception:\r
-            logging.debug('problem pinging google did you register you sitemap with google?')\r
-\r
-    def __unicode__(self):\r
-        return self.comment
\ No newline at end of file
+from django.utils.translation import ugettext as _
+from base import *
+
+class Vote(models.Model):
+    user = models.ForeignKey(User, related_name="votes")
+    node = models.ForeignKey(Node, related_name="votes")
+    value = models.SmallIntegerField()
+    action = models.OneToOneField(Action, related_name="vote")
+    voted_at = models.DateTimeField(default=datetime.datetime.now)
+
+    class Meta:
+        app_label = 'forum'
+        unique_together = ('user', 'node')
+
+
+class Flag(models.Model):
+    user = models.ForeignKey(User, related_name="flags")
+    node = models.ForeignKey(Node, related_name="flags")
+    reason = models.CharField(max_length=300)
+    action = models.OneToOneField(Action, related_name="flag")
+    flagged_at = models.DateTimeField(default=datetime.datetime.now)
+
+    class Meta:
+        app_label = 'forum'
+        unique_together = ('user', 'node')
+
+
+class Badge(BaseModel):
+    GOLD = 1
+    SILVER = 2
+    BRONZE = 3
+
+    type        = models.SmallIntegerField()
+    cls         = models.CharField(max_length=50, null=True)
+    awarded_count = models.PositiveIntegerField(default=0)
+    
+    awarded_to    = models.ManyToManyField(User, through='Award', related_name='badges')
+
+    def get_handler(self):
+        from forum.badges import BadgesMeta
+        return BadgesMeta.by_id.get(self.id, None)
+
+    @property
+    def name(self):
+        cls = self.get_handler()
+        return cls and cls.name or _("Unknown")
+
+    @property
+    def description(self):
+        cls = self.get_handler()
+        return cls and cls.description or _("No description available")
+
+    @models.permalink
+    def get_absolute_url(self):
+        return ('badge', [], {'id': self.id, 'slug': slugify(self.name)})
+
+    def save(self, *args, **kwargs):
+        if isinstance(self.awarded_count, models.expressions.ExpressionNode):
+            super(Badge, self).save(*args, **kwargs)
+            self.awarded_count = self.__class__.objects.filter(id=self.id).values_list('awarded_count', flat=True)[0]
+        else:
+            super(Badge, self).save(*args, **kwargs)
+
+
+    class Meta:
+        app_label = 'forum'
+
+
+class Award(models.Model):
+    user = models.ForeignKey(User)
+    badge = models.ForeignKey('Badge', related_name="awards")
+    node = models.ForeignKey(Node, null=True)
+
+    awarded_at = models.DateTimeField(default=datetime.datetime.now)
+
+    trigger = models.ForeignKey(Action, related_name="awards", null=True)
+    action = models.OneToOneField(Action, related_name="award")
+
+
+    class Meta:
+        unique_together = ('user', 'badge', 'node')
+        app_label = 'forum'
\ No newline at end of file