X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/d958b0a69d6cebf7a4465c552d9392449f0e35fc..4bbb2156110a75e84ef95ee28ba31490d986b870:/forum/models/tag.py diff --git a/forum/models/tag.py b/forum/models/tag.py index 067488b..eca23e4 100644 --- a/forum/models/tag.py +++ b/forum/models/tag.py @@ -1,6 +1,8 @@ import datetime from base import * +from django.conf import settings as django_settings +from django.core.cache.backends.base import BaseCache from django.utils.translation import ugettext as _ from django.utils.encoding import smart_unicode, force_unicode @@ -9,8 +11,8 @@ 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) + def get_queryset(self): + return super(ActiveTagManager, self).get_queryset().exclude(used_count__lt=1) class Tag(BaseModel): name = models.CharField(max_length=255, unique=True) @@ -45,7 +47,12 @@ class Tag(BaseModel): @classmethod def infer_cache_key(cls, querydict): if 'name' in querydict: - return cls._generate_cache_key(cls.safe_cache_name(querydict['name'])) + cache_key = cls._generate_cache_key(cls.safe_cache_name(querydict['name'])) + + if len(cache_key) > django_settings.CACHE_MAX_KEY_LENGTH: + cache_key = cache_key[:django_settings.CACHE_MAX_KEY_LENGTH] + + return cache_key return None