##// 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
@@ -1,13 +1,13
1 1 """
2 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 7 __version__ = '.'.join((str(each) for each in VERSION[:4]))
8 8
9 9 def get_version():
10 10 """
11 11 Returns shorter version (digit parts only) as string.
12 12 """
13 13 return '.'.join((str(each) for each in VERSION[:3]))
@@ -1,72 +1,73
1 1 """Pylons middleware initialization"""
2 2 from beaker.middleware import SessionMiddleware
3 3 from paste.cascade import Cascade
4 4 from paste.registry import RegistryManager
5 5 from paste.urlparser import StaticURLParser
6 6 from paste.deploy.converters import asbool
7 7 from pylons.middleware import ErrorHandler, StatusCodeRedirect
8 8 from pylons.wsgiapp import PylonsApp
9 9 from routes.middleware import RoutesMiddleware
10 10 from pylons_app.lib.middleware.simplehg import SimpleHg
11 11 from pylons_app.lib.middleware.https_fixup import HttpsFixup
12 12 from pylons_app.config.environment import load_environment
13 13
14 14 def make_app(global_conf, full_stack=True, static_files=True, **app_conf):
15 15 """Create a Pylons WSGI application and return it
16 16
17 17 ``global_conf``
18 18 The inherited configuration for this application. Normally from
19 19 the [DEFAULT] section of the Paste ini file.
20 20
21 21 ``full_stack``
22 22 Whether or not this application provides a full WSGI stack (by
23 23 default, meaning it handles its own exceptions and errors).
24 24 Disable full_stack when this application is "managed" by
25 25 another WSGI middleware.
26 26
27 27 ``app_conf``
28 28 The application's local configuration. Normally specified in
29 29 the [app:<name>] section of the Paste ini file (where <name>
30 30 defaults to main).
31 31
32 32 """
33 33 # Configure the Pylons environment
34 34 config = load_environment(global_conf, app_conf)
35 35
36 36
37 37 # The Pylons WSGI app
38 38 app = PylonsApp(config=config)
39 39
40 40
41 41 # Routing/Session/Cache Middleware
42 42 app = RoutesMiddleware(app, config['routes.map'])
43 43 app = SessionMiddleware(app, config)
44 44
45 45 # CUSTOM MIDDLEWARE HERE (filtered by error handling middlewares)
46 46 #set the https based on HTTP_X_URL_SCHEME
47 app = HttpsFixup(app)
47
48 48 app = SimpleHg(app, config)
49 49
50 50 if asbool(full_stack):
51 51 # Handle Python exceptions
52 52 app = ErrorHandler(app, global_conf, **config['pylons.errorware'])
53 53
54 54 # Display error documents for 401, 403, 404 status codes (and
55 55 # 500 when debug is disabled)
56 56 if asbool(config['debug']):
57 57 app = StatusCodeRedirect(app)
58 58 else:
59 59 app = StatusCodeRedirect(app, [400, 401, 403, 404, 500])
60 60
61 app = HttpsFixup(app)
61 62 # Establish the Registry for this application
62 63 app = RegistryManager(app)
63 64
64 65 if asbool(static_files):
65 66 # Serve static files
66 67 static_app = StaticURLParser(config['pylons.paths']['static_files'])
67 68 app = Cascade([static_app, app])
68 69
69 70 app.config = config
70 71
71 72 return app
72 73
@@ -1,22 +1,61
1 1 #!/usr/bin/python
2 2 # -*- coding: utf-8 -*-
3 3 import logging
4 4 from operator import itemgetter
5 from pylons import tmpl_context as c, request, config
6 from pylons_app.lib.base import BaseController, render
5 from pylons import tmpl_context as c, request, config, url, response
6 from pylons_app.lib.base import BaseController, render, _full_changelog_cached
7 7 from pylons_app.lib.utils import get_repo_slug
8 8 from pylons_app.model.hg_model import HgModel
9 9 from pylons_app.lib.auth import LoginRequired
10 from webhelpers.feedgenerator import Atom1Feed, Rss201rev2Feed
10 11 log = logging.getLogger(__name__)
11 12
12 13 class FeedController(BaseController):
13 14
14 15 #secure it or not ?
15 16 def __before__(self):
16 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
24
25 def atom(self, repo_name):
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)
17 32
18 def atom(self):
19 return 'Hello Atom'
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')
43
20 44
21 def rss(self):
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