##// END OF EJS Templates
Added support for repository located in subdirectories.
marcink -
r248:fb7f0661 default
parent child Browse files
Show More
@@ -22,8 +22,32 def make_map(config):
22 22 map.connect('hg_home', '/', controller='hg', action='index')
23 23
24 24
25 #REST controllers
26 map.resource('repo', 'repos', path_prefix='/_admin')
25 #REST routes
26 with map.submapper(path_prefix='/_admin', controller='repos') as m:
27 m.connect("repos", "/repos",
28 action="create", conditions=dict(method=["POST"]))
29 m.connect("repos", "/repos",
30 action="index", conditions=dict(method=["GET"]))
31 m.connect("formatted_repos", "/repos.{format}",
32 action="index",
33 conditions=dict(method=["GET"]))
34 m.connect("new_repo", "/repos/new",
35 action="new", conditions=dict(method=["GET"]))
36 m.connect("formatted_new_repo", "/repos/new.{format}",
37 action="new", conditions=dict(method=["GET"]))
38 m.connect("/repos/{id:.*}",
39 action="update", conditions=dict(method=["PUT"]))
40 m.connect("/repos/{id:.*}",
41 action="delete", conditions=dict(method=["DELETE"]))
42 m.connect("edit_repo", "/repos/{id:.*}/edit",
43 action="edit", conditions=dict(method=["GET"]))
44 m.connect("formatted_edit_repo", "/repos/{id:.*}.{format}/edit",
45 action="edit", conditions=dict(method=["GET"]))
46 m.connect("repo", "/repos/{id:.*}",
47 action="show", conditions=dict(method=["GET"]))
48 m.connect("formatted_repo", "/repos/{id:.*}.{format}",
49 action="show", conditions=dict(method=["GET"]))
50
27 51 map.resource('user', 'users', path_prefix='/_admin')
28 52 map.resource('permission', 'permissions', path_prefix='/_admin')
29 53
@@ -34,34 +58,34 def make_map(config):
34 58 action='add_repo')
35 59
36 60 #FEEDS
37 map.connect('rss_feed_home', '/{repo_name}/feed/rss',
61 map.connect('rss_feed_home', '/{repo_name:.*}/feed/rss',
38 62 controller='feed', action='rss')
39 map.connect('atom_feed_home', '/{repo_name}/feed/atom',
63 map.connect('atom_feed_home', '/{repo_name:.*}/feed/atom',
40 64 controller='feed', action='atom')
41 65
42 66 map.connect('login_home', '/login', controller='login')
43 67 map.connect('logout_home', '/logout', controller='login', action='logout')
44 68
45 map.connect('changeset_home', '/{repo_name}/changeset/{revision}',
69 map.connect('changeset_home', '/{repo_name:.*}/changeset/{revision}',
46 70 controller='changeset', revision='tip')
47 map.connect('summary_home', '/{repo_name}/summary',
71 map.connect('summary_home', '/{repo_name:.*}/summary',
48 72 controller='summary')
49 map.connect('shortlog_home', '/{repo_name}/shortlog',
73 map.connect('shortlog_home', '/{repo_name:.*}/shortlog',
50 74 controller='shortlog')
51 map.connect('branches_home', '/{repo_name}/branches',
75 map.connect('branches_home', '/{repo_name:.*}/branches',
52 76 controller='branches')
53 map.connect('tags_home', '/{repo_name}/tags',
77 map.connect('tags_home', '/{repo_name:.*}/tags',
54 78 controller='tags')
55 map.connect('changelog_home', '/{repo_name}/changelog',
79 map.connect('changelog_home', '/{repo_name:.*}/changelog',
56 80 controller='changelog')
57 map.connect('files_home', '/{repo_name}/files/{revision}/{f_path:.*}',
81 map.connect('files_home', '/{repo_name:.*}/files/{revision}/{f_path:.*}',
58 82 controller='files', revision='tip', f_path='')
59 map.connect('files_diff_home', '/{repo_name}/diff/{f_path:.*}',
83 map.connect('files_diff_home', '/{repo_name:.*}/diff/{f_path:.*}',
60 84 controller='files', action='diff', revision='tip', f_path='')
61 map.connect('files_raw_home', '/{repo_name}/rawfile/{revision}/{f_path:.*}',
85 map.connect('files_raw_home', '/{repo_name:.*}/rawfile/{revision}/{f_path:.*}',
62 86 controller='files', action='rawfile', revision='tip', f_path='')
63 map.connect('files_annotate_home', '/{repo_name}/annotate/{revision}/{f_path:.*}',
87 map.connect('files_annotate_home', '/{repo_name:.*}/annotate/{revision}/{f_path:.*}',
64 88 controller='files', action='annotate', revision='tip', f_path='')
65 map.connect('files_archive_home', '/{repo_name}/archive/{revision}/{fileformat}',
89 map.connect('files_archive_home', '/{repo_name:.*}/archive/{revision}/{fileformat}',
66 90 controller='files', action='archivefile', revision='tip')
67 91 return map
@@ -2,6 +2,8 from pylons import request, response, se
2 2 app_globals as g
3 3 from pylons.controllers.util import abort, redirect
4 4 from pylons_app.lib.auth import LoginRequired
5 from pylons.i18n.translation import _
6 from pylons_app.lib import helpers as h
5 7 from pylons_app.lib.base import BaseController, render
6 8 from pylons_app.lib.filters import clean_repo
7 9 from pylons_app.lib.utils import check_repo, invalidate_cache
@@ -39,6 +41,7 class ReposController(BaseController):
39 41 self._create_repo(name)
40 42 #clear our cached list for refresh with new repo
41 43 invalidate_cache('cached_repo_list')
44 h.flash(_('created repository %s') % name, category='success')
42 45 except Exception as e:
43 46 log.error(e)
44 47
@@ -85,7 +88,7 class ReposController(BaseController):
85 88
86 89 #clear our cached list for refresh with new repo
87 90 invalidate_cache('cached_repo_list')
88
91 h.flash(_('deleted repository %s') % rm_path, category='success')
89 92 return redirect(url('repos'))
90 93
91 94
@@ -50,8 +50,9 class SimpleHg(object):
50 50 return result.wsgi_application(environ, start_response)
51 51
52 52 try:
53 repo_name = environ['PATH_INFO'].split('/')[1]
54 except:
53 repo_name = '/'.join(environ['PATH_INFO'].split('/')[1:])
54 except Exception as e:
55 log.error(e)
55 56 return HTTPNotFound()(environ, start_response)
56 57
57 58 #since we wrap into hgweb, just reset the path
@@ -63,6 +64,7 class SimpleHg(object):
63 64 try:
64 65 app = wsgiapplication(self.__make_app)
65 66 except Exception as e:
67 log.error(e)
66 68 return HTTPNotFound()(environ, start_response)
67 69 action = self.__get_action(environ)
68 70 #invalidate cache on push
@@ -6,10 +6,7 log = logging.getLogger(__name__)
6 6
7 7
8 8 def get_repo_slug(request):
9 path_info = request.environ.get('PATH_INFO')
10 uri_lst = path_info.split('/')
11 repo_name = uri_lst[1]
12 return repo_name
9 return request.environ['pylons.routes_dict'].get('repo_name')
13 10
14 11 def is_mercurial(environ):
15 12 """
@@ -131,14 +128,7 class EmptyChangeset(BaseChangeset):
131 128
132 129 def repo2db_mapper():
133 130 """
134 put !
131 scann all dirs for .hgdbid
132 if some dir doesn't have one generate one.
135 133 """
136 pass
137 #scann all dirs for .hgdbid
138 #if some dir doesn't have one generate one.
139 #
140
141
142
143
144
134 pass No newline at end of file
@@ -82,7 +82,13 class HgModel(object):
82 82 repos_list = {}
83 83 for name, path in repos:
84 84 try:
85 #name = name.split('/')[-1]
86 if repos_list.has_key(name):
87 raise RepositoryError('Duplicate repository name %s found in'
88 ' %s' % (name, path))
89 else:
85 90 repos_list[name] = MercurialRepository(path, baseui=baseui)
91 repos_list[name].name = name
86 92 except OSError:
87 93 continue
88 94 return repos_list
General Comments 0
You need to be logged in to leave comments. Login now