diff pylons_app/controllers/feed.py @ 207:8bdec09436cb rhodecode-0.0.0.7.1

bumped version to 0.7.1 added atom and rss feeds. Moved https Fixud middleware before error middleware to proper generate debug page (static imports)
author Marcin Kuzminski <marcin@python-works.com>
date Sun, 23 May 2010 02:07:56 +0200
parents 66b20f525750
children a83a1799480c
line wrap: on
line diff
--- a/pylons_app/controllers/feed.py	Sun May 23 01:07:58 2010 +0200
+++ b/pylons_app/controllers/feed.py	Sun May 23 02:07:56 2010 +0200
@@ -2,11 +2,12 @@
 # -*- coding: utf-8 -*-
 import logging
 from operator import itemgetter
-from pylons import tmpl_context as c, request, config
-from pylons_app.lib.base import BaseController, render
+from pylons import tmpl_context as c, request, config, url, response
+from pylons_app.lib.base import BaseController, render, _full_changelog_cached
 from pylons_app.lib.utils import get_repo_slug
 from pylons_app.model.hg_model import HgModel
 from pylons_app.lib.auth import LoginRequired
+from webhelpers.feedgenerator import Atom1Feed, Rss201rev2Feed
 log = logging.getLogger(__name__)
 
 class FeedController(BaseController):
@@ -14,9 +15,47 @@
     #secure it or not ?
     def __before__(self):
         super(FeedController, self).__before__()
+        #common values for feeds
+        self.description = 'Changes on %s repository'
+        self.title = "%s feed"
+        self.language = 'en-us'
+        self.ttl = "5"
+        self.feed_nr = 10
+
+    def atom(self, repo_name):
+        """Produce an atom-1.0 feed via feedgenerator module"""
+        feed = Atom1Feed(title=self.title % repo_name,
+                         link=url('summary_home', repo_name=repo_name, qualified=True),
+                         description=self.description % repo_name,
+                         language=self.language,
+                         ttl=self.ttl)
         
-    def atom(self):
-        return 'Hello Atom'
+        
+        for cnt, cs in enumerate(_full_changelog_cached(repo_name)):
+            if cnt > self.feed_nr:
+                break
+            feed.add_item(title=cs.message,
+                          link=url('changeset_home', repo_name=repo_name, revision=cs.raw_id, qualified=True),
+                          description=str(cs.date))
+        
+        response.content_type = feed.mime_type
+        return feed.writeString('utf-8')
+
     
-    def rss(self):
-        return 'Hello rss'
+    def rss(self, repo_name):
+        """Produce an rss2 feed via feedgenerator module"""
+        feed = Rss201rev2Feed(title=self.title % repo_name,
+                         link=url('summary_home', repo_name=repo_name, qualified=True),
+                         description=self.description % repo_name,
+                         language=self.language,
+                         ttl=self.ttl)
+        
+        for cnt, cs in enumerate(_full_changelog_cached(repo_name)):
+            if cnt > self.feed_nr:
+                break
+            feed.add_item(title=cs.message,
+                          link=url('changeset_home', repo_name=repo_name, revision=cs.raw_id, qualified=True),
+                          description=str(cs.date))
+            
+        response.content_type = feed.mime_type
+        return feed.writeString('utf-8')