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),
|
2011-04-11 21:57:45 -04:00
|
|
|
make_option("-a", "--all", default=False, action='store_true'),
|
2010-08-31 22:00:46 -04:00
|
|
|
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('?')
|
2011-04-11 21:57:45 -04:00
|
|
|
if options['all']:
|
|
|
|
feeds = Feed.objects.all()
|
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
|
2010-12-23 13:29:31 -05:00
|
|
|
day = now - datetime.timedelta(days=1)
|
2011-02-22 09:37:09 -05:00
|
|
|
feeds = Feed.objects.filter(
|
|
|
|
last_update__lte=day,
|
|
|
|
queued_date__lte=day,
|
|
|
|
min_to_decay__lte=60*24,
|
2012-08-09 13:26:44 -07:00
|
|
|
active_subscribers__gte=1
|
|
|
|
).order_by('?')[:50]
|
2011-02-22 09:37:09 -05:00
|
|
|
if feeds: Feed.task_feeds(feeds)
|
|
|
|
|
|
|
|
week = now - datetime.timedelta(days=7)
|
2010-12-23 12:32:24 -05:00
|
|
|
feeds = Feed.objects.filter(
|
|
|
|
last_update__lte=week,
|
2010-12-23 12:39:28 -05:00
|
|
|
queued_date__lte=day,
|
2012-08-09 13:26:44 -07:00
|
|
|
active_subscribers__gte=1
|
|
|
|
).order_by('?')[:50]
|
2012-02-01 17:59:46 -08:00
|
|
|
if feeds: Feed.task_feeds(feeds)
|
|
|
|
|
2012-02-24 17:07:42 -08:00
|
|
|
# feeds = Feed.objects.filter(
|
|
|
|
# last_update__lte=day,
|
|
|
|
# active_subscribers__gte=1,
|
|
|
|
# active=False,
|
|
|
|
# known_good=True
|
|
|
|
# ).order_by('?')
|
|
|
|
# if feeds: Feed.task_feeds(feeds)
|