Mercurial > public > src > rhodecode
changeset 207:8bdec09436cb v0.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 | 7a6a69f3b9ec |
children | c674d994b07c |
files | pylons_app/__init__.py pylons_app/config/middleware.py pylons_app/controllers/feed.py |
diffstat | 3 files changed, 48 insertions(+), 8 deletions(-) [+] |
line wrap: on
line diff
--- a/pylons_app/__init__.py Sun May 23 01:07:58 2010 +0200 +++ b/pylons_app/__init__.py Sun May 23 02:07:56 2010 +0200 @@ -2,7 +2,7 @@ Hg app, a web based mercurial repository managment based on pylons """ -VERSION = (0, 7, 0, 'beta') +VERSION = (0, 7, 1, 'beta') __version__ = '.'.join((str(each) for each in VERSION[:4]))
--- a/pylons_app/config/middleware.py Sun May 23 01:07:58 2010 +0200 +++ b/pylons_app/config/middleware.py Sun May 23 02:07:56 2010 +0200 @@ -44,7 +44,7 @@ # CUSTOM MIDDLEWARE HERE (filtered by error handling middlewares) #set the https based on HTTP_X_URL_SCHEME - app = HttpsFixup(app) + app = SimpleHg(app, config) if asbool(full_stack): @@ -58,6 +58,7 @@ else: app = StatusCodeRedirect(app, [400, 401, 403, 404, 500]) + app = HttpsFixup(app) # Establish the Registry for this application app = RegistryManager(app)
--- 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')