2010-08-31 22:00:46 -04:00
|
|
|
from django.core.management.base import BaseCommand
|
|
|
|
from django.conf import settings
|
|
|
|
from apps.rss_feeds.models import Feed
|
|
|
|
from optparse import make_option
|
2010-09-20 19:22:19 -04:00
|
|
|
from apps.rss_feeds.tasks import UpdateFeeds
|
2010-09-28 19:50:29 -04:00
|
|
|
from celery.task import Task
|
2010-08-31 22:00:46 -04:00
|
|
|
import datetime
|
|
|
|
|
|
|
|
|
|
|
|
class Command(BaseCommand):
|
|
|
|
option_list = BaseCommand.option_list + (
|
|
|
|
make_option("-f", "--feed", default=None),
|
|
|
|
make_option("-F", "--force", dest="force", action="store_true"),
|
|
|
|
make_option('-V', '--verbose', action='store_true',
|
|
|
|
dest='verbose', default=False, help='Verbose output.'),
|
|
|
|
)
|
|
|
|
|
|
|
|
def handle(self, *args, **options):
|
|
|
|
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-09-17 12:50:46 -04:00
|
|
|
feeds = Feed.objects.filter(
|
|
|
|
next_scheduled_update__lte=now,
|
|
|
|
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-08-31 22:00:46 -04:00
|
|
|
|
|
|
|
if options['force']:
|
2010-09-01 10:44:29 -04:00
|
|
|
feeds = Feed.objects.all().order_by('pk')
|
2010-08-31 22:00:46 -04:00
|
|
|
|
|
|
|
print " ---> Tasking %s feeds..." % feeds.count()
|
2010-09-01 10:44:29 -04:00
|
|
|
|
2010-09-28 19:50:29 -04:00
|
|
|
publisher = Task.get_publisher()
|
|
|
|
|
2010-09-01 10:44:29 -04:00
|
|
|
feed_queue = []
|
2010-09-28 19:50:29 -04:00
|
|
|
size = 12
|
2010-08-31 22:00:46 -04:00
|
|
|
for f in feeds:
|
2010-10-10 23:55:00 -04:00
|
|
|
f.queued_date = datetime.datetime.utcnow()
|
2010-08-31 22:04:26 -04:00
|
|
|
f.set_next_scheduled_update()
|
2010-10-03 22:38:53 -04:00
|
|
|
|
2010-09-28 19:50:29 -04:00
|
|
|
for feed_queue in (feeds[pos:pos + size] for pos in xrange(0, len(feeds), size)):
|
2010-09-17 12:53:05 -04:00
|
|
|
print feed_queue
|
2010-09-28 19:50:29 -04:00
|
|
|
feed_ids = [feed.pk for feed in feed_queue]
|
|
|
|
print feed_ids
|
|
|
|
UpdateFeeds.apply_async(args=(feed_ids,), queue='update_feeds', publisher=publisher)
|
|
|
|
|
2010-10-12 13:17:43 -04:00
|
|
|
publisher.connection.close()
|