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, |
|
|
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