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)