view gpp/bulletins/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 65016249bf35
children
line wrap: on
line source
"""Models for the bulletins app.
Bulletins allow the sited admins to display and manage important notices for the website.
"""

import datetime
from django.db import models
from django.db.models import Q


class BulletinManager(models.Manager):
    """Manager for the Bulletin model."""

    def get_current(self):
        now = datetime.datetime.now()
        return self.filter(
                Q(is_enabled=True),
                Q(start_date__lte=now),
                Q(end_date__isnull=True) | Q(end_date__gte=now))


class Bulletin(models.Model):
    """Model to represent site bulletins."""
    title = models.CharField(max_length=200)
    text = models.TextField()
    start_date = models.DateTimeField(db_index=True,
            help_text='Start date for when the bulletin will be active.',)
    end_date = models.DateTimeField(blank=True, null=True, db_index=True,
            help_text='End date for the bulletin. Leave blank to keep it open-ended.')
    is_enabled = models.BooleanField(default=True, db_index=True,
            help_text='Check to allow the bulletin to be viewed on the site.')

    objects = BulletinManager()

    class Meta:
        ordering = ('-start_date', )

    def __unicode__(self):
        return self.title