2010-08-31 22:00:46 -04:00
|
|
|
from django.core.management.base import BaseCommand
|
|
|
|
from django.conf import settings
|
|
|
|
from optparse import make_option
|
|
|
|
import datetime
|
|
|
|
|
|
|
|
|
|
|
|
class Command(BaseCommand):
|
|
|
|
option_list = BaseCommand.option_list + (
|
|
|
|
make_option("-f", "--feed", default=None),
|
|
|
|
make_option('-V', '--verbose', action='store_true',
|
|
|
|
dest='verbose', default=False, help='Verbose output.'),
|
|
|
|
)
|
|
|
|
|
|
|
|
def handle(self, *args, **options):
|
2010-12-23 12:32:24 -05:00
|
|
|
from apps.rss_feeds.models import Feed
|
2010-08-31 22:00:46 -04:00
|
|
|
settings.LOG_TO_STREAM = True
|
2010-10-10 23:55:00 -04:00
|
|
|
now = datetime.datetime.utcnow()
|
2010-08-31 22:00:46 -04:00
|
|
|
|
2010-12-23 12:32:24 -05:00
|
|
|
# Active feeds
|
2010-09-17 12:50:46 -04:00
|
|
|
feeds = Feed.objects.filter(
|
2010-12-23 12:32:24 -05:00
|
|
|
next_scheduled_update__lte=now,
|
2010-09-17 12:50:46 -04:00
|
|
|
active=True
|
|
|
|
).exclude(
|
2010-09-17 12:51:25 -04:00
|
|
|
active_subscribers=0
|
2010-09-17 12:50:46 -04:00
|
|
|
).order_by('?')
|
2010-12-23 12:32:24 -05:00
|
|
|
Feed.task_feeds(feeds)
|
2010-08-31 22:00:46 -04:00
|
|
|
|
2010-12-23 12:32:24 -05:00
|
|
|
# Mistakenly inactive feeds
|
|
|
|
week = datetime.datetime.now() - datetime.timedelta(days=7)
|
|
|
|
feeds = Feed.objects.filter(
|
|
|
|
last_update__lte=week,
|
|
|
|
active_subscribers__gte=1
|
|
|
|
).order_by('?')
|
|
|
|
if feeds: Feed.task_feeds(feeds)
|