summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIsmael Carnales <icarnales@gmail.com>2009-10-30 19:24:26 -0200
committerIsmael Carnales <icarnales@gmail.com>2009-11-09 22:24:44 -0200
commit19f0a3fb57e53977d1f2017033f0714a8cfc8779 (patch)
treecdce7728ceec7202086f0cd7605a496887ee0afe
parent046b4543a4ceaf4cfe6736443d4a7e453b5bf14b (diff)
added feeds from archweb_pub
-rw-r--r--feeds.py36
-rw-r--r--templates/feeds/news_description.html4
-rw-r--r--templates/feeds/news_title.html1
-rw-r--r--templates/feeds/packages_description.html1
-rw-r--r--templates/feeds/packages_title.html1
-rw-r--r--urls.py11
6 files changed, 54 insertions, 0 deletions
diff --git a/feeds.py b/feeds.py
new file mode 100644
index 00000000..cc6f3278
--- /dev/null
+++ b/feeds.py
@@ -0,0 +1,36 @@
+import datetime
+from django.contrib.syndication.feeds import Feed
+from archweb.main.models import Package, News
+#from datetime import datetime
+
+class PackageFeed(Feed):
+ title = 'Recent Package Updates'
+ link = '/packages/'
+ description = 'Recent Package Updates'
+
+ def items(self):
+ return Package.objects.order_by('-last_update')[:24]
+
+ def item_pubdate(self, item):
+ return item.last_update
+
+ def item_categories(self, item):
+ return (item.repo.name,item.arch.name)
+
+class NewsFeed(Feed):
+ title = 'Recent News Updates'
+ link = '/news/'
+ description = 'Recent News Updates'
+
+ def items(self):
+ return News.objects.order_by('-postdate', '-id')[:10]
+
+ def item_pubdate(self, item):
+ d = item.postdate
+ return datetime.datetime(d.year, d.month, d.day)
+
+ def item_author_name(self, item):
+ return item.author.get_full_name()
+
+# vim: set ts=4 sw=4 et:
+
diff --git a/templates/feeds/news_description.html b/templates/feeds/news_description.html
new file mode 100644
index 00000000..c428b9e2
--- /dev/null
+++ b/templates/feeds/news_description.html
@@ -0,0 +1,4 @@
+{% autoescape off %}
+{{obj.author.get_full_name}} wrote:<br />
+{{ obj.content }}
+{% endautoescape %}
diff --git a/templates/feeds/news_title.html b/templates/feeds/news_title.html
new file mode 100644
index 00000000..d355de5b
--- /dev/null
+++ b/templates/feeds/news_title.html
@@ -0,0 +1 @@
+{{ obj.title }}
diff --git a/templates/feeds/packages_description.html b/templates/feeds/packages_description.html
new file mode 100644
index 00000000..6b9c47b3
--- /dev/null
+++ b/templates/feeds/packages_description.html
@@ -0,0 +1 @@
+{{ obj.pkgdesc }}
diff --git a/templates/feeds/packages_title.html b/templates/feeds/packages_title.html
new file mode 100644
index 00000000..910c6207
--- /dev/null
+++ b/templates/feeds/packages_title.html
@@ -0,0 +1 @@
+{{ obj.pkgname }} {{ obj.pkgver }}-{{ obj.pkgrel }} {{ obj.arch.name }}
diff --git a/urls.py b/urls.py
index 9aa879b1..0fda8d5a 100644
--- a/urls.py
+++ b/urls.py
@@ -7,6 +7,13 @@ from django.views.generic.simple import direct_to_template
from django.contrib.auth.decorators import permission_required
from archweb.main.models import Todolist
+from archweb.feeds import PackageFeed, NewsFeed
+
+
+feeds = {
+ 'packages': PackageFeed,
+ 'news': NewsFeed
+}
admin.autodiscover()
@@ -50,6 +57,10 @@ urlpatterns = patterns('',
(r'^devel/newuser/$', 'archweb.devel.views.new_user_form'),
+# Feeds and sitemaps
+ (r'^feeds/(?P<url>.*)/$',
+ 'django.contrib.syndication.views.feed', {'feed_dict': feeds}),
+
# Authentication / Admin
(r'^login/$', 'django.contrib.auth.views.login', {
'template_name': 'registration/login.html'}),