annotate gpp/downloads/search_indexes.py @ 479:32cec6cd8808

Refactor RateLimiter so that if Redis is not running, everything still runs normally (minus the rate limiting protection). My assumption that creating a Redis connection would throw an exception if Redis wasn't running was wrong. The exceptions actually occur when you issue a command. This is for #224.
author Brian Neal <bgneal@gmail.com>
date Sun, 25 Sep 2011 00:49:05 +0000
parents 3b30286adba5
children 387d46abcb95
rev   line source
bgneal@221 1 """Haystack search index for the downloads application."""
bgneal@221 2 from haystack.indexes import *
bgneal@221 3 from haystack import site
bgneal@469 4 from custom_search.indexes import CondQueuedSearchIndex
bgneal@221 5
bgneal@221 6 from downloads.models import Download
bgneal@221 7
bgneal@221 8
bgneal@467 9 class DownloadIndex(CondQueuedSearchIndex):
bgneal@221 10 text = CharField(document=True, use_template=True)
bgneal@221 11 author = CharField(model_attr='user')
bgneal@221 12 pub_date = DateTimeField(model_attr='date_added')
bgneal@221 13
bgneal@221 14 def get_queryset(self):
bgneal@221 15 return Download.public_objects.all()
bgneal@221 16
bgneal@277 17 def get_updated_field(self):
bgneal@277 18 return 'update_date'
bgneal@277 19
bgneal@467 20 def can_index(self, instance):
bgneal@467 21 return instance.is_public
bgneal@221 22
bgneal@221 23 site.register(Download, DownloadIndex)