NewsBlur-viq/apps/rss_feeds/tasks.py

60 lines
1.6 KiB
Python
Raw Normal View History

from celery.task import Task
2011-04-11 21:57:45 -04:00
from utils import log as logging
from django.conf import settings
class UpdateFeeds(Task):
name = 'update-feeds'
max_retries = 0
2010-09-01 08:19:58 -04:00
ignore_result = True
def run(self, feed_pks, **kwargs):
from apps.rss_feeds.models import Feed
from apps.statistics.models import MStatistics
options = {
'fake': bool(MStatistics.get('fake_fetch')),
'quick': float(MStatistics.get('quick_fetch', 0)),
}
if not isinstance(feed_pks, list):
feed_pks = [feed_pks]
for feed_pk in feed_pks:
2011-04-11 21:57:45 -04:00
try:
feed = Feed.objects.get(pk=feed_pk)
feed.update(**options)
2011-04-11 21:57:45 -04:00
except Feed.DoesNotExist:
logging.info(" ---> Feed doesn't exist: [%s]" % feed_pk)
# logging.debug(' Updating: [%s] %s' % (feed_pks, feed))
2010-09-28 05:16:00 -04:00
class NewFeeds(Task):
name = 'new-feeds'
2010-09-28 05:16:00 -04:00
max_retries = 0
ignore_result = True
def run(self, feed_pks, **kwargs):
from apps.rss_feeds.models import Feed
2010-09-28 05:16:00 -04:00
if not isinstance(feed_pks, list):
feed_pks = [feed_pks]
options = {
'force': True,
}
2010-09-28 05:16:00 -04:00
for feed_pk in feed_pks:
feed = Feed.objects.get(pk=feed_pk)
feed.update(options=options)
class PushFeeds(Task):
name = 'push-feeds'
max_retries = 0
ignore_result = True
def run(self, feed_id, xml, **kwargs):
from apps.rss_feeds.models import Feed
options = {
'feed_xml': xml
}
feed = Feed.objects.get(pk=feed_id)
feed.update(options=options)