view gpp/forums/management/commands/forum_cleanup.py @ 388:c3231af55778

For #191; r410 is wrong: it is returning the wrong posts. Rework. MySQL is not using an index on our query, and it is taking 10+ seconds. Replace this slow query with a loop that loops over the public forums, then sorts and returns the posts.
author Brian Neal <bgneal@gmail.com>
date Sat, 19 Mar 2011 05:03:51 +0000
parents 7e19180b128d
children
line wrap: on
line source
"""
forum_cleanup.py - A management command to cleanup forum model objects. Right
now this entails deleting old forum and topic last visit records.

"""
import datetime

from django.core.management.base import NoArgsCommand, CommandError

from forums.models import ForumLastVisit, TopicLastVisit
import forums.unread


class Command(NoArgsCommand):
    help = "This command deletes old forum and topic last visit records."

    def handle_noargs(self, **opts):

        now = datetime.datetime.now()
        threshold = now - forums.unread.THRESHOLD * 2

        # delete old topic last visit records
        TopicLastVisit.objects.filter(last_visit__lt=threshold).delete()

        # delete old forum visit records
        ForumLastVisit.objects.filter(end_date__lt=threshold).delete()