Mercurial > public > sg101
view gpp/custom_search/indexes.py @ 552:9e42e6618168
For bitbucket issue #2, tweak the admin settings for the Post model to
reduce slow queries. Define our own queryset() method so we can control the
select_related(), and not have it cascade from post to topics to forums to
categories. Removed 'topic' from list_display because MySQL still sucked with
2 inner joins. Now it seems to be tolerable with only one join to User.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Wed, 25 Jan 2012 20:07:03 -0600 |
parents | 3b30286adba5 |
children |
line wrap: on
line source
""" This module contains custom search indexes to tailor the Haystack search application to our needs. """ from queued_search.indexes import QueuedSearchIndex class CondQueuedSearchIndex(QueuedSearchIndex): """ This customized version of QueuedSearchIndex conditionally enqueues items to be indexed by calling the can_index() method. """ def can_index(self, instance): """ The default is to index all instances. Override this method to customize the behavior. This will be called on all update operations. """ return True def enqueue(self, action, instance): """ This method enqueues the instance only if the can_index() method returns True. """ if (action == 'update' and self.can_index(instance) or action == 'delete'): super(CondQueuedSearchIndex, self).enqueue(action, instance)