##// END OF EJS Templates
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)
marcink -
r207:8bdec094 rhodecode-0.0.0.7.1 default
parent child Browse files
Show More
@@ -2,7 +2,7 b''
2 Hg app, a web based mercurial repository managment based on pylons
2 Hg app, a web based mercurial repository managment based on pylons
3 """
3 """
4
4
5 VERSION = (0, 7, 0, 'beta')
5 VERSION = (0, 7, 1, 'beta')
6
6
7 __version__ = '.'.join((str(each) for each in VERSION[:4]))
7 __version__ = '.'.join((str(each) for each in VERSION[:4]))
8
8
@@ -44,7 +44,7 b' def make_app(global_conf, full_stack=Tru'
44
44
45 # CUSTOM MIDDLEWARE HERE (filtered by error handling middlewares)
45 # CUSTOM MIDDLEWARE HERE (filtered by error handling middlewares)
46 #set the https based on HTTP_X_URL_SCHEME
46 #set the https based on HTTP_X_URL_SCHEME
47 app = HttpsFixup(app)
47
48 app = SimpleHg(app, config)
48 app = SimpleHg(app, config)
49
49
50 if asbool(full_stack):
50 if asbool(full_stack):
@@ -58,6 +58,7 b' def make_app(global_conf, full_stack=Tru'
58 else:
58 else:
59 app = StatusCodeRedirect(app, [400, 401, 403, 404, 500])
59 app = StatusCodeRedirect(app, [400, 401, 403, 404, 500])
60
60
61 app = HttpsFixup(app)
61 # Establish the Registry for this application
62 # Establish the Registry for this application
62 app = RegistryManager(app)
63 app = RegistryManager(app)
63
64
@@ -2,11 +2,12 b''
2 # -*- coding: utf-8 -*-
2 # -*- coding: utf-8 -*-
3 import logging
3 import logging
4 from operator import itemgetter
4 from operator import itemgetter
5 from pylons import tmpl_context as c, request, config
5 from pylons import tmpl_context as c, request, config, url, response
6 from pylons_app.lib.base import BaseController, render
6 from pylons_app.lib.base import BaseController, render, _full_changelog_cached
7 from pylons_app.lib.utils import get_repo_slug
7 from pylons_app.lib.utils import get_repo_slug
8 from pylons_app.model.hg_model import HgModel
8 from pylons_app.model.hg_model import HgModel
9 from pylons_app.lib.auth import LoginRequired
9 from pylons_app.lib.auth import LoginRequired
10 from webhelpers.feedgenerator import Atom1Feed, Rss201rev2Feed
10 log = logging.getLogger(__name__)
11 log = logging.getLogger(__name__)
11
12
12 class FeedController(BaseController):
13 class FeedController(BaseController):
@@ -14,9 +15,47 b' class FeedController(BaseController):'
14 #secure it or not ?
15 #secure it or not ?
15 def __before__(self):
16 def __before__(self):
16 super(FeedController, self).__before__()
17 super(FeedController, self).__before__()
18 #common values for feeds
19 self.description = 'Changes on %s repository'
20 self.title = "%s feed"
21 self.language = 'en-us'
22 self.ttl = "5"
23 self.feed_nr = 10
17
24
18 def atom(self):
25 def atom(self, repo_name):
19 return 'Hello Atom'
26 """Produce an atom-1.0 feed via feedgenerator module"""
27 feed = Atom1Feed(title=self.title % repo_name,
28 link=url('summary_home', repo_name=repo_name, qualified=True),
29 description=self.description % repo_name,
30 language=self.language,
31 ttl=self.ttl)
32
33
34 for cnt, cs in enumerate(_full_changelog_cached(repo_name)):
35 if cnt > self.feed_nr:
36 break
37 feed.add_item(title=cs.message,
38 link=url('changeset_home', repo_name=repo_name, revision=cs.raw_id, qualified=True),
39 description=str(cs.date))
40
41 response.content_type = feed.mime_type
42 return feed.writeString('utf-8')
20
43
21 def rss(self):
44
22 return 'Hello rss'
45 def rss(self, repo_name):
46 """Produce an rss2 feed via feedgenerator module"""
47 feed = Rss201rev2Feed(title=self.title % repo_name,
48 link=url('summary_home', repo_name=repo_name, qualified=True),
49 description=self.description % repo_name,
50 language=self.language,
51 ttl=self.ttl)
52
53 for cnt, cs in enumerate(_full_changelog_cached(repo_name)):
54 if cnt > self.feed_nr:
55 break
56 feed.add_item(title=cs.message,
57 link=url('changeset_home', repo_name=repo_name, revision=cs.raw_id, qualified=True),
58 description=str(cs.date))
59
60 response.content_type = feed.mime_type
61 return feed.writeString('utf-8')
General Comments 0
You need to be logged in to leave comments. Login now