Mercurial > public > sg101
view gpp/antispam/models.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 | 8c1832b9d815 |
children |
line wrap: on
line source
"""Models for the antispam application.""" from django.db import models from django.core.cache import cache from antispam import SPAM_PHRASE_KEY class SpamPhrase(models.Model): """A SpamPhrase is a string that is checked for in user input. User input containing a SpamPhrase should be blocked and flagged. """ phrase = models.CharField(max_length=64) class Meta: ordering = ('phrase', ) def __unicode__(self): return self.phrase def save(self, *args, **kwargs): cache.delete(SPAM_PHRASE_KEY) self.phrase = self.phrase.lower() super(SpamPhrase, self).save(*args, **kwargs)