from base import *
from utils import PickledObjectField
+from django.conf import settings as django_settings
from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned
from django.contrib.contenttypes.models import ContentType
from django.contrib.auth.models import User as DjangoUser, AnonymousUser as DjangoAnonymousUser
-from django.db.models import Q
+from django.db.models import Q, Manager
from django.utils.encoding import smart_unicode
return decorated
return decorator
+class UserManager(CachedManager):
+ def get(self, *args, **kwargs):
+ if not len(args) and len(kwargs) == 1 and 'username' in kwargs:
+ matching_users = self.filter(username=kwargs['username'])
+
+ if len(matching_users) == 1:
+ return matching_users[0]
+ elif len(matching_users) > 1:
+ for user in matching_users:
+ if user.username == kwargs['username']:
+ return user
+ return matching_users[0]
+ return super(UserManager, self).get(*args, **kwargs)
+
class User(BaseModel, DjangoUser):
is_approved = models.BooleanField(default=False)
email_isvalid = models.BooleanField(default=False)
vote_up_count = DenormalizedField("actions", canceled=False, action_type="voteup")
vote_down_count = DenormalizedField("actions", canceled=False, action_type="votedown")
+ objects = UserManager()
+
def __unicode__(self):
return smart_unicode(self.username)
#todo: temporary thing, for now lets just assume that the site owner will always be the first user of the application
return self.id == 1
- @property
- def decorated_name(self):
+
+ def _decorated_name(self):
username = smart_unicode(self.username)
if len(username) > TRUNCATE_USERNAMES_LONGER_THAN and TRUNCATE_LONG_USERNAMES:
return username
+ @property
+ def decorated_name(self):
+ return self._decorated_name()
+
@property
def last_activity(self):
try:
@classmethod
def infer_cache_key(cls, querydict):
if 'user' in querydict and 'key' in querydict:
- return cls._generate_cache_key("%s:%s" % (querydict['user'].id, querydict['key']))
+ cache_key = cls._generate_cache_key("%s:%s" % (querydict['user'].id, querydict['key']))
+ 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