Mercurial > public > sg101
view wiki/tasks.py @ 791:0ca691cccf8d
Utilize select_related() for user & user profiles.
This commit also removes the caching of the avatar URL in the
avatar template tag. This is because we are now using select_related,
so we already have the profile & avatar when we get to the tag.
Thus we don't need to waste time querying the cache.
Removed an apparently unused member map template as well.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Fri, 23 May 2014 21:52:41 -0500 |
parents | aeafbf3ecebf |
children |
line wrap: on
line source
""" Celery tasks for the wiki app. """ from __future__ import absolute_import import datetime import logging import time from celery import shared_task from django.conf import settings import redis from core.services import get_redis_connection logger = logging.getLogger(__name__) @shared_task def expire_cookies(): """ Periodically run this task to remove expired cookies from the Redis set that is shared between this Django application & the MoinMoin wiki for authentication. """ now = datetime.datetime.utcnow() cutoff = now - datetime.timedelta(seconds=settings.WIKI_COOKIE_AGE) min_score = time.mktime(cutoff.utctimetuple()) conn = get_redis_connection() set_name = settings.WIKI_REDIS_SET try: count = conn.zcard(set_name) except redis.RedisError: logger.error("Error getting zcard") return try: removed = conn.zremrangebyscore(set_name, 0.0, min_score) except redis.RedisError: logger.error("Error removing by score") return total = count - removed logger.info("Expire wiki cookies: removed %d, total is now %d", removed, total)