Mercurial > public > sg101
view gpp/bio/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 | 387d46abcb95 |
children | 98b373ca09f3 |
line wrap: on
line source
"""Haystack search index for the bio application.""" from haystack.indexes import * from haystack import site from custom_search.indexes import CondQueuedSearchIndex from bio.models import UserProfile from bio.signals import profile_content_update class UserProfileIndex(CondQueuedSearchIndex): text = CharField(document=True, use_template=True) author = CharField(model_attr='user') def index_queryset(self): return UserProfile.objects.filter(user__is_active=True) def get_updated_field(self): return 'update_date' def _setup_save(self, model): profile_content_update.connect(self.enqueue_save) def _teardown_save(self, model): profile_content_update.disconnect(self.enqueue_save) def enqueue_save(self, sender, **kwargs): return self.enqueue('update', sender) def can_index(self, instance): return instance.user.is_active site.register(UserProfile, UserProfileIndex)