X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/0ba16baba0615dd405486c7d87f943d71518375c..9b7822cca75d3fdd36f5a4cfa858272214621578:/forum/models/tag.py diff --git a/forum/models/tag.py b/forum/models/tag.py index 1344597..067488b 100644 --- a/forum/models/tag.py +++ b/forum/models/tag.py @@ -1,53 +1,64 @@ +import datetime from base import * from django.utils.translation import ugettext as _ -import django.dispatch +from django.utils.encoding import smart_unicode, force_unicode -class ActiveTagManager(models.Manager): - def get_query_set(self): - return super(ActiveTagManager, self).get_query_set().exclude(deleted=False, used_count=0) +from forum import modules + +class ActiveTagManager(CachedManager): + use_for_related_fields = True + def get_query_set(self): + return super(ActiveTagManager, self).get_query_set().exclude(used_count__lt=1) class Tag(BaseModel): name = models.CharField(max_length=255, unique=True) created_by = models.ForeignKey(User, related_name='created_tags') + created_at = models.DateTimeField(default=datetime.datetime.now, blank=True, null=True) marked_by = models.ManyToManyField(User, related_name="marked_tags", through="MarkedTag") # Denormalised data used_count = models.PositiveIntegerField(default=0) - deleted = models.BooleanField(default=False) - deleted_at = models.DateTimeField(null=True, blank=True) - deleted_by = models.ForeignKey(User, null=True, blank=True, related_name='deleted_%(class)ss') - active = ActiveTagManager() - def mark_deleted(self, user): - if not self.deleted: - self.deleted = True - self.deleted_at = datetime.datetime.now() - self.deleted_by = user - self.save() - return True - else: - return False - - def unmark_deleted(self): - if self.deleted: - self.deleted = False - self.save() - return True - else: - return False - class Meta: ordering = ('-used_count', 'name') app_label = 'forum' def __unicode__(self): - return self.name + return force_unicode(self.name) + + def add_to_usage_count(self, value): + if self.used_count + value < 0: + self.used_count = 0 + else: + self.used_count = models.F('used_count') + value + + def cache_key(self): + return self._generate_cache_key(Tag.safe_cache_name(self.name)) + + @classmethod + def safe_cache_name(cls, name): + return "".join([str(ord(c)) for c in name]) + + @classmethod + def infer_cache_key(cls, querydict): + if 'name' in querydict: + return cls._generate_cache_key(cls.safe_cache_name(querydict['name'])) + + return None + + @classmethod + def value_to_list_on_cache_query(cls): + return 'name' + + @models.permalink + def get_absolute_url(self): + return ('tag_questions', (), {'tag': self.name}) class MarkedTag(models.Model): - TAG_MARK_REASONS = (('good',_('interesting')),('bad',_('ignored'))) + TAG_MARK_REASONS = (('good', _('interesting')), ('bad', _('ignored'))) tag = models.ForeignKey(Tag, related_name='user_selections') user = models.ForeignKey(User, related_name='tag_selections') reason = models.CharField(max_length=16, choices=TAG_MARK_REASONS)