X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/d8b33aea55fb1b9450ad310894516d3315a64722..f73c15a3bd47e9f7fe3a29645f968528fb6415e4:/forum/models/tag.py diff --git a/forum/models/tag.py b/forum/models/tag.py index dd628c8..5b6bef3 100644 --- a/forum/models/tag.py +++ b/forum/models/tag.py @@ -5,7 +5,7 @@ from django.utils.translation import ugettext as _ from forum import modules -class ActiveTagManager(models.Manager): +class ActiveTagManager(CachedManager): use_for_related_fields = True def get_query_set(self): @@ -26,7 +26,7 @@ class Tag(BaseModel): app_label = 'forum' def __unicode__(self): - return u'%s' % self.name + return self.name def add_to_usage_count(self, value): if self.used_count + value < 0: @@ -34,6 +34,24 @@ class Tag(BaseModel): 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})