Show More
@@ -147,6 +147,7 b' class ReposController(BaseController):' | |||
|
147 | 147 | |
|
148 | 148 | except formencode.Invalid, errors: |
|
149 | 149 | c.repo_info = repo_model.get_by_repo_name(repo_name) |
|
150 | ||
|
150 | 151 | if c.repo_info.stats: |
|
151 | 152 | last_rev = c.repo_info.stats.stat_on_revision |
|
152 | 153 | else: |
@@ -281,8 +282,9 b' class ReposController(BaseController):' | |||
|
281 | 282 | def edit(self, repo_name, format='html'): |
|
282 | 283 | """GET /repos/repo_name/edit: Form to edit an existing item""" |
|
283 | 284 | # url('edit_repo', repo_name=ID) |
|
285 | r = ScmModel().get(repo_name)[0] | |
|
286 | ||
|
284 | 287 | repo_model = RepoModel() |
|
285 | r = ScmModel().get(repo_name) | |
|
286 | 288 | c.repo_info = repo_model.get_by_repo_name(repo_name) |
|
287 | 289 | |
|
288 | 290 | if c.repo_info is None: |
@@ -45,8 +45,7 b' class BranchesController(BaseController)' | |||
|
45 | 45 | super(BranchesController, self).__before__() |
|
46 | 46 | |
|
47 | 47 | def index(self): |
|
48 | hg_model = ScmModel() | |
|
49 | c.repo_info = hg_model.get_repo(c.repo_name) | |
|
48 | c.repo_info, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
50 | 49 | c.repo_branches = OrderedDict() |
|
51 | 50 | for name, hash_ in c.repo_info.branches.items(): |
|
52 | 51 | c.repo_branches[name] = c.repo_info.get_changeset(hash_) |
@@ -67,14 +67,14 b' class ChangelogController(BaseController' | |||
|
67 | 67 | else: |
|
68 | 68 | c.size = int(session.get('changelog_size', default)) |
|
69 | 69 | |
|
70 |
|
|
|
70 | repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
71 | 71 | |
|
72 | 72 | p = int(request.params.get('page', 1)) |
|
73 |
c.total_cs = len( |
|
|
74 |
c.pagination = Page( |
|
|
73 | c.total_cs = len(repo) | |
|
74 | c.pagination = Page(repo, page=p, item_count=c.total_cs, | |
|
75 | 75 | items_per_page=c.size) |
|
76 | 76 | |
|
77 |
self._graph( |
|
|
77 | self._graph(repo, c.size, p) | |
|
78 | 78 | |
|
79 | 79 | return render('changelog/changelog.html') |
|
80 | 80 |
@@ -55,7 +55,6 b' class ChangesetController(BaseController' | |||
|
55 | 55 | super(ChangesetController, self).__before__() |
|
56 | 56 | |
|
57 | 57 | def index(self, revision): |
|
58 | hg_model = ScmModel() | |
|
59 | 58 | |
|
60 | 59 | def wrap_to_table(str): |
|
61 | 60 | |
@@ -70,7 +69,7 b' class ChangesetController(BaseController' | |||
|
70 | 69 | rev_range = revision.split('...')[:2] |
|
71 | 70 | range_limit = 50 |
|
72 | 71 | try: |
|
73 |
repo = |
|
|
72 | repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
74 | 73 | if len(rev_range) == 2: |
|
75 | 74 | rev_start = rev_range[0] |
|
76 | 75 | rev_end = rev_range[1] |
@@ -163,12 +162,11 b' class ChangesetController(BaseController' | |||
|
163 | 162 | |
|
164 | 163 | def raw_changeset(self, revision): |
|
165 | 164 | |
|
166 | hg_model = ScmModel() | |
|
167 | 165 | method = request.GET.get('diff', 'show') |
|
168 | 166 | try: |
|
169 |
r = |
|
|
170 | c.scm_type = r.alias | |
|
171 | c.changeset = r.get_changeset(revision) | |
|
167 | repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
168 | c.scm_type = repo.alias | |
|
169 | c.changeset = repo.get_changeset(revision) | |
|
172 | 170 | except RepositoryError: |
|
173 | 171 | log.error(traceback.format_exc()) |
|
174 | 172 | return redirect(url('home')) |
@@ -28,6 +28,7 b'' | |||
|
28 | 28 | import logging |
|
29 | 29 | |
|
30 | 30 | from pylons import url, response |
|
31 | from pylons.i18n.translation import _ | |
|
31 | 32 | |
|
32 | 33 | from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAnyDecorator |
|
33 | 34 | from rhodecode.lib.base import BaseController |
@@ -45,7 +46,7 b' class FeedController(BaseController):' | |||
|
45 | 46 | def __before__(self): |
|
46 | 47 | super(FeedController, self).__before__() |
|
47 | 48 | #common values for feeds |
|
48 | self.description = 'Changes on %s repository' | |
|
49 | self.description = _('Changes on %s repository') | |
|
49 | 50 | self.title = "%s feed" |
|
50 | 51 | self.language = 'en-us' |
|
51 | 52 | self.ttl = "5" |
@@ -59,9 +60,9 b' class FeedController(BaseController):' | |||
|
59 | 60 | language=self.language, |
|
60 | 61 | ttl=self.ttl) |
|
61 | 62 | |
|
62 |
|
|
|
63 | repo, dbrepo = ScmModel().get(repo_name, retval='repo') | |
|
63 | 64 | |
|
64 |
for cs in |
|
|
65 | for cs in repo[:self.feed_nr]: | |
|
65 | 66 | feed.add_item(title=cs.message, |
|
66 | 67 | link=url('changeset_home', repo_name=repo_name, |
|
67 | 68 | revision=cs.raw_id, qualified=True), |
@@ -79,8 +80,8 b' class FeedController(BaseController):' | |||
|
79 | 80 | language=self.language, |
|
80 | 81 | ttl=self.ttl) |
|
81 | 82 | |
|
82 |
|
|
|
83 |
for cs in |
|
|
83 | repo, dbrepo = ScmModel().get(repo_name, retval='repo') | |
|
84 | for cs in repo[:self.feed_nr]: | |
|
84 | 85 | feed.add_item(title=cs.message, |
|
85 | 86 | link=url('changeset_home', repo_name=repo_name, |
|
86 | 87 | revision=cs.raw_id, qualified=True), |
@@ -57,8 +57,8 b' class FilesController(BaseController):' | |||
|
57 | 57 | c.cut_off_limit = self.cut_off_limit |
|
58 | 58 | |
|
59 | 59 | def index(self, repo_name, revision, f_path): |
|
60 | hg_model = ScmModel() | |
|
61 | c.repo = hg_model.get_repo(c.repo_name) | |
|
60 | c.repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
61 | ||
|
62 | 62 | |
|
63 | 63 | try: |
|
64 | 64 | #reditect to given revision from form |
@@ -116,8 +116,7 b' class FilesController(BaseController):' | |||
|
116 | 116 | return render('files/files.html') |
|
117 | 117 | |
|
118 | 118 | def rawfile(self, repo_name, revision, f_path): |
|
119 | hg_model = ScmModel() | |
|
120 | c.repo = hg_model.get_repo(c.repo_name) | |
|
119 | c.repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
121 | 120 | file_node = c.repo.get_changeset(revision).get_node(f_path) |
|
122 | 121 | response.content_type = file_node.mimetype |
|
123 | 122 | response.content_disposition = 'attachment; filename=%s' \ |
@@ -125,16 +124,14 b' class FilesController(BaseController):' | |||
|
125 | 124 | return file_node.content |
|
126 | 125 | |
|
127 | 126 | def raw(self, repo_name, revision, f_path): |
|
128 | hg_model = ScmModel() | |
|
129 | c.repo = hg_model.get_repo(c.repo_name) | |
|
127 | c.repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
130 | 128 | file_node = c.repo.get_changeset(revision).get_node(f_path) |
|
131 | 129 | response.content_type = 'text/plain' |
|
132 | 130 | |
|
133 | 131 | return file_node.content |
|
134 | 132 | |
|
135 | 133 | def annotate(self, repo_name, revision, f_path): |
|
136 | hg_model = ScmModel() | |
|
137 | c.repo = hg_model.get_repo(c.repo_name) | |
|
134 | c.repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
138 | 135 | |
|
139 | 136 | try: |
|
140 | 137 | c.cs = c.repo.get_changeset(revision) |
@@ -163,9 +160,9 b' class FilesController(BaseController):' | |||
|
163 | 160 | ext = ext_data[1] |
|
164 | 161 | |
|
165 | 162 | try: |
|
166 |
repo = ScmModel().get |
|
|
163 | repo, dbrepo = ScmModel().get(repo_name) | |
|
167 | 164 | |
|
168 |
if |
|
|
165 | if dbrepo.enable_downloads is False: | |
|
169 | 166 | return _('downloads disabled') |
|
170 | 167 | |
|
171 | 168 | cs = repo.get_changeset(revision) |
@@ -185,13 +182,12 b' class FilesController(BaseController):' | |||
|
185 | 182 | |
|
186 | 183 | |
|
187 | 184 | def diff(self, repo_name, f_path): |
|
188 | hg_model = ScmModel() | |
|
189 | 185 | diff1 = request.GET.get('diff1') |
|
190 | 186 | diff2 = request.GET.get('diff2') |
|
191 | 187 | c.action = request.GET.get('diff') |
|
192 | 188 | c.no_changes = diff1 == diff2 |
|
193 | 189 | c.f_path = f_path |
|
194 |
c.repo = |
|
|
190 | c.repo, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
195 | 191 | |
|
196 | 192 | try: |
|
197 | 193 | if diff1 not in ['', None, 'None', '0' * 12, '0' * 40]: |
@@ -47,7 +47,7 b' class ShortlogController(BaseController)' | |||
|
47 | 47 | |
|
48 | 48 | def index(self): |
|
49 | 49 | p = int(request.params.get('page', 1)) |
|
50 |
repo = ScmModel().get |
|
|
50 | repo, dbrepo = ScmModel().get(c.repo_name, 'repo') | |
|
51 | 51 | c.repo_changesets = Page(repo, page=p, items_per_page=20) |
|
52 | 52 | c.shortlog_data = render('shortlog/shortlog_data.html') |
|
53 | 53 | if request.params.get('partial'): |
@@ -64,13 +64,14 b' class SummaryController(BaseController):' | |||
|
64 | 64 | |
|
65 | 65 | def index(self): |
|
66 | 66 | scm_model = ScmModel() |
|
67 |
c.repo |
|
|
67 | c.repo, dbrepo = scm_model.get(c.repo_name) | |
|
68 | c.dbrepo = dbrepo | |
|
68 | 69 | c.following = scm_model.is_following_repo(c.repo_name, |
|
69 | 70 | c.rhodecode_user.user_id) |
|
70 | 71 | def url_generator(**kw): |
|
71 | 72 | return url('shortlog_home', repo_name=c.repo_name, **kw) |
|
72 | 73 | |
|
73 |
c.repo_changesets = Page(c.repo |
|
|
74 | c.repo_changesets = Page(c.repo, page=1, items_per_page=10, | |
|
74 | 75 | url=url_generator) |
|
75 | 76 | |
|
76 | 77 | e = request.environ |
@@ -92,16 +93,16 b' class SummaryController(BaseController):' | |||
|
92 | 93 | 'repo_name':c.repo_name, } |
|
93 | 94 | c.clone_repo_url = uri |
|
94 | 95 | c.repo_tags = OrderedDict() |
|
95 |
for name, hash in c.repo |
|
|
96 | for name, hash in c.repo.tags.items()[:10]: | |
|
96 | 97 | try: |
|
97 |
c.repo_tags[name] = c.repo |
|
|
98 | c.repo_tags[name] = c.repo.get_changeset(hash) | |
|
98 | 99 | except ChangesetError: |
|
99 | 100 | c.repo_tags[name] = EmptyChangeset(hash) |
|
100 | 101 | |
|
101 | 102 | c.repo_branches = OrderedDict() |
|
102 |
for name, hash in c.repo |
|
|
103 | for name, hash in c.repo.branches.items()[:10]: | |
|
103 | 104 | try: |
|
104 |
c.repo_branches[name] = c.repo |
|
|
105 | c.repo_branches[name] = c.repo.get_changeset(hash) | |
|
105 | 106 | except ChangesetError: |
|
106 | 107 | c.repo_branches[name] = EmptyChangeset(hash) |
|
107 | 108 | |
@@ -113,21 +114,21 b' class SummaryController(BaseController):' | |||
|
113 | 114 | ts_min_y = mktime(td_1y.timetuple()) |
|
114 | 115 | ts_max_y = mktime(td.timetuple()) |
|
115 | 116 | |
|
116 |
if |
|
|
117 | if dbrepo.enable_statistics: | |
|
117 | 118 | c.no_data_msg = _('No data loaded yet') |
|
118 |
run_task(get_commits_stats, c.repo |
|
|
119 | run_task(get_commits_stats, c.repo.name, ts_min_y, ts_max_y) | |
|
119 | 120 | else: |
|
120 | 121 | c.no_data_msg = _('Statistics update are disabled for this repository') |
|
121 | 122 | c.ts_min = ts_min_m |
|
122 | 123 | c.ts_max = ts_max_y |
|
123 | 124 | |
|
124 | 125 | stats = self.sa.query(Statistics)\ |
|
125 |
.filter(Statistics.repository == |
|
|
126 | .filter(Statistics.repository == dbrepo)\ | |
|
126 | 127 | .scalar() |
|
127 | 128 | |
|
128 | 129 | |
|
129 | 130 | if stats and stats.languages: |
|
130 |
c.no_data = False is |
|
|
131 | c.no_data = False is dbrepo.enable_statistics | |
|
131 | 132 | lang_stats = json.loads(stats.languages) |
|
132 | 133 | c.commit_data = stats.commit_activity |
|
133 | 134 | c.overview_data = stats.commit_activity_combined |
@@ -142,9 +143,9 b' class SummaryController(BaseController):' | |||
|
142 | 143 | c.trending_languages = json.dumps({}) |
|
143 | 144 | c.no_data = True |
|
144 | 145 | |
|
145 |
c.enable_downloads = |
|
|
146 | c.enable_downloads = dbrepo.enable_downloads | |
|
146 | 147 | if c.enable_downloads: |
|
147 |
c.download_options = self._get_download_links(c.repo |
|
|
148 | c.download_options = self._get_download_links(c.repo) | |
|
148 | 149 | |
|
149 | 150 | return render('summary/summary.html') |
|
150 | 151 |
@@ -44,8 +44,7 b' class TagsController(BaseController):' | |||
|
44 | 44 | super(TagsController, self).__before__() |
|
45 | 45 | |
|
46 | 46 | def index(self): |
|
47 | hg_model = ScmModel() | |
|
48 | c.repo_info = hg_model.get_repo(c.repo_name) | |
|
47 | c.repo_info, dbrepo = ScmModel().get(c.repo_name, retval='repo') | |
|
49 | 48 | c.repo_tags = OrderedDict() |
|
50 | 49 | for name, hash_ in c.repo_info.tags.items(): |
|
51 | 50 | c.repo_tags[name] = c.repo_info.get_changeset(hash_) |
@@ -28,12 +28,12 b' class BaseController(WSGIController):' | |||
|
28 | 28 | #c.unread_journal = scm_model.get_unread_journal() |
|
29 | 29 | |
|
30 | 30 | if c.repo_name: |
|
31 |
|
|
|
32 |
if |
|
|
33 |
c.repository_tags = |
|
|
34 |
c.repository_branches = |
|
|
35 |
c.repository_followers = scm_model.get_followers( |
|
|
36 |
c.repository_forks = scm_model.get_forks( |
|
|
31 | repo, dbrepo = scm_model.get(c.repo_name) | |
|
32 | if repo: | |
|
33 | c.repository_tags = repo.tags | |
|
34 | c.repository_branches = repo.branches | |
|
35 | c.repository_followers = scm_model.get_followers(dbrepo.repo_id) | |
|
36 | c.repository_forks = scm_model.get_forks(dbrepo.repo_id) | |
|
37 | 37 | else: |
|
38 | 38 | c.repository_tags = {} |
|
39 | 39 | c.repository_branches = {} |
@@ -483,12 +483,12 b' def action_parser(user_log):' | |||
|
483 | 483 | def get_fork_name(): |
|
484 | 484 | from rhodecode.model.scm import ScmModel |
|
485 | 485 | repo_name = action_params |
|
486 | repo = ScmModel().get(repo_name) | |
|
486 | repo, dbrepo = ScmModel().get(repo_name) | |
|
487 | 487 | if repo is None: |
|
488 | 488 | return repo_name |
|
489 | 489 | return link_to(action_params, url('summary_home', |
|
490 | 490 | repo_name=repo.name,), |
|
491 |
title= |
|
|
491 | title=dbrepo.description) | |
|
492 | 492 | |
|
493 | 493 | map = {'user_deleted_repo':(_('User [deleted] repository'), None), |
|
494 | 494 | 'user_created_repo':(_('User [created] repository'), None), |
@@ -87,7 +87,7 b' class RepoModel(BaseModel):' | |||
|
87 | 87 | if cache: |
|
88 | 88 | repo = repo.options(FromCache("sql_cache_long", |
|
89 | 89 | "get_repo_full_%s" % repo_name)) |
|
90 | if invalidate: | |
|
90 | if invalidate and cache: | |
|
91 | 91 | repo.invalidate() |
|
92 | 92 | |
|
93 | 93 | return repo.scalar() |
@@ -31,8 +31,6 b' import logging' | |||
|
31 | 31 | |
|
32 | 32 | from mercurial import ui |
|
33 | 33 | |
|
34 | from sqlalchemy.orm import joinedload | |
|
35 | from sqlalchemy.orm.session import make_transient | |
|
36 | 34 | from sqlalchemy.exc import DatabaseError |
|
37 | 35 | |
|
38 | 36 | from beaker.cache import cache_region, region_invalidate |
@@ -45,9 +43,11 b' from vcs.utils.lazy import LazyProperty' | |||
|
45 | 43 | from rhodecode import BACKENDS |
|
46 | 44 | from rhodecode.lib import helpers as h |
|
47 | 45 | from rhodecode.lib.auth import HasRepoPermissionAny |
|
48 |
from rhodecode.lib.utils import get_repos as get_filesystem_repos, make_ui, |
|
|
46 | from rhodecode.lib.utils import get_repos as get_filesystem_repos, make_ui, \ | |
|
47 | action_logger | |
|
49 | 48 | from rhodecode.model import BaseModel |
|
50 | 49 | from rhodecode.model.user import UserModel |
|
50 | from rhodecode.model.repo import RepoModel | |
|
51 | 51 | from rhodecode.model.db import Repository, RhodeCodeUi, CacheInvalidation, \ |
|
52 | 52 | UserFollowing, UserLog |
|
53 | 53 | from rhodecode.model.caching_query import FromCache |
@@ -82,17 +82,18 b' class ScmModel(BaseModel):' | |||
|
82 | 82 | |
|
83 | 83 | return q.ui_value |
|
84 | 84 | |
|
85 |
def repo_scan(self, repos_path |
|
|
85 | def repo_scan(self, repos_path=None): | |
|
86 | 86 | """Listing of repositories in given path. This path should not be a |
|
87 | 87 | repository itself. Return a dictionary of repository objects |
|
88 | 88 | |
|
89 | 89 | :param repos_path: path to directory containing repositories |
|
90 | :param baseui: baseui instance to instantiate MercurialRepostitory with | |
|
91 | 90 | """ |
|
92 | 91 | |
|
93 | 92 | log.info('scanning for repositories in %s', repos_path) |
|
94 | 93 | |
|
95 | if not isinstance(baseui, ui.ui): | |
|
94 | if repos_path is None: | |
|
95 | repos_path = self.repos_path | |
|
96 | ||
|
96 | 97 |
|
|
97 | 98 | repos_list = {} |
|
98 | 99 | |
@@ -134,7 +135,7 b' class ScmModel(BaseModel):' | |||
|
134 | 135 | |
|
135 | 136 | for r in all_repos: |
|
136 | 137 | |
|
137 | repo = self.get(r.repo_name, invalidation_list) | |
|
138 | repo, dbrepo = self.get(r.repo_name, invalidation_list) | |
|
138 | 139 | |
|
139 | 140 | if repo is not None: |
|
140 | 141 | last_change = repo.last_change |
@@ -143,33 +144,34 b' class ScmModel(BaseModel):' | |||
|
143 | 144 | tmp_d = {} |
|
144 | 145 | tmp_d['name'] = r.repo_name |
|
145 | 146 | tmp_d['name_sort'] = tmp_d['name'].lower() |
|
146 |
tmp_d['description'] = |
|
|
147 | tmp_d['description'] = dbrepo.description | |
|
147 | 148 | tmp_d['description_sort'] = tmp_d['description'] |
|
148 | 149 | tmp_d['last_change'] = last_change |
|
149 | 150 | tmp_d['last_change_sort'] = time.mktime(last_change.timetuple()) |
|
150 | 151 | tmp_d['tip'] = tip.raw_id |
|
151 | 152 | tmp_d['tip_sort'] = tip.revision |
|
152 | 153 | tmp_d['rev'] = tip.revision |
|
153 |
tmp_d['contact'] = |
|
|
154 | tmp_d['contact'] = dbrepo.user.full_contact | |
|
154 | 155 | tmp_d['contact_sort'] = tmp_d['contact'] |
|
155 | 156 | tmp_d['owner_sort'] = tmp_d['contact'] |
|
156 | 157 | tmp_d['repo_archives'] = list(repo._get_archives()) |
|
157 | 158 | tmp_d['last_msg'] = tip.message |
|
158 | 159 | tmp_d['repo'] = repo |
|
160 | tmp_d['dbrepo'] = dbrepo | |
|
159 | 161 | yield tmp_d |
|
160 | 162 | |
|
161 | def get_repo(self, repo_name): | |
|
162 | return self.get(repo_name) | |
|
163 | ||
|
164 | def get(self, repo_name, invalidation_list=None): | |
|
165 | """Get's repository from given name, creates BackendInstance and | |
|
163 | def get(self, repo_name, invalidation_list=None, retval='all'): | |
|
164 | """Returns a tuple of Repository,DbRepository, | |
|
165 | Get's repository from given name, creates BackendInstance and | |
|
166 | 166 | propagates it's data from database with all additional information |
|
167 | 167 | |
|
168 | 168 | :param repo_name: |
|
169 | 169 | :param invalidation_list: if a invalidation list is given the get |
|
170 | 170 | method should not manually check if this repository needs |
|
171 | 171 | invalidation and just invalidate the repositories in list |
|
172 | ||
|
172 | :param retval: string specifing what to return one of 'repo','dbrepo', | |
|
173 | 'all'if repo or dbrepo is given it'll just lazy load chosen type | |
|
174 | and return None as the second | |
|
173 | 175 | """ |
|
174 | 176 | if not HasRepoPermissionAny('repository.read', 'repository.write', |
|
175 | 177 | 'repository.admin')(repo_name, 'get repo check'): |
@@ -189,58 +191,45 b' class ScmModel(BaseModel):' | |||
|
189 | 191 | backend = get_backend(alias) |
|
190 | 192 | except VCSError: |
|
191 | 193 | log.error(traceback.format_exc()) |
|
192 |
log.error('Perhaps this repository is in db and not in |
|
|
193 |
'run rescan repositories with |
|
|
194 | 'option from admin panel') | |
|
194 | log.error('Perhaps this repository is in db and not in ' | |
|
195 | 'filesystem run rescan repositories with ' | |
|
196 | '"destroy old data " option from admin panel') | |
|
195 | 197 | return |
|
196 | 198 | |
|
197 | 199 | if alias == 'hg': |
|
198 | from pylons import app_globals as g | |
|
199 | repo = backend(repo_path, create=False, baseui=g.baseui) | |
|
200 | repo = backend(repo_path, create=False, baseui=make_ui('db')) | |
|
200 | 201 | #skip hidden web repository |
|
201 | 202 | if repo._get_hidden(): |
|
202 | 203 | return |
|
203 | 204 | else: |
|
204 | 205 | repo = backend(repo_path, create=False) |
|
205 | 206 | |
|
206 | dbrepo = self.sa.query(Repository)\ | |
|
207 | .options(joinedload(Repository.fork))\ | |
|
208 | .options(joinedload(Repository.user))\ | |
|
209 | .filter(Repository.repo_name == repo_name)\ | |
|
210 | .scalar() | |
|
211 | ||
|
212 | self.sa.expunge_all() | |
|
213 | log.debug('making transient %s', dbrepo) | |
|
214 | make_transient(dbrepo) | |
|
215 | ||
|
216 | for attr in ['user', 'forks', 'followers', 'group', 'repo_to_perm', | |
|
217 | 'users_group_to_perm', 'stats', 'logs']: | |
|
218 | attr = getattr(dbrepo, attr, False) | |
|
219 | if attr: | |
|
220 | if isinstance(attr, list): | |
|
221 | for a in attr: | |
|
222 | log.debug('making transient %s', a) | |
|
223 | make_transient(a) | |
|
224 | else: | |
|
225 | log.debug('making transient %s', attr) | |
|
226 | make_transient(attr) | |
|
227 | ||
|
228 | repo.dbrepo = dbrepo | |
|
229 | 207 | return repo |
|
230 | 208 | |
|
231 | 209 | pre_invalidate = True |
|
210 | dbinvalidate = False | |
|
211 | ||
|
232 | 212 | if invalidation_list is not None: |
|
233 | 213 | pre_invalidate = repo_name in invalidation_list |
|
234 | 214 | |
|
235 | 215 | if pre_invalidate: |
|
216 | #this returns object to invalidate | |
|
236 | 217 | invalidate = self._should_invalidate(repo_name) |
|
237 | ||
|
238 | 218 | if invalidate: |
|
239 | 219 | log.info('invalidating cache for repository %s', repo_name) |
|
240 | region_invalidate(_get_repo, None, repo_name) | |
|
220 | #region_invalidate(_get_repo, None, repo_name) | |
|
241 | 221 | self._mark_invalidated(invalidate) |
|
222 | dbinvalidate = True | |
|
242 | 223 | |
|
243 | return _get_repo(repo_name) | |
|
224 | r, dbr = None, None | |
|
225 | if retval == 'repo' or 'all': | |
|
226 | r = _get_repo(repo_name) | |
|
227 | if retval == 'dbrepo' or 'all': | |
|
228 | dbr = RepoModel(self.sa).get_full(repo_name, cache=True, | |
|
229 | invalidate=dbinvalidate) | |
|
230 | ||
|
231 | ||
|
232 | return r, dbr | |
|
244 | 233 | |
|
245 | 234 | |
|
246 | 235 | |
@@ -370,8 +359,6 b' class ScmModel(BaseModel):' | |||
|
370 | 359 | """ |
|
371 | 360 | |
|
372 | 361 | ret = self.sa.query(CacheInvalidation)\ |
|
373 | .options(FromCache('sql_cache_short', | |
|
374 | 'get_invalidation_%s' % repo_name))\ | |
|
375 | 362 | .filter(CacheInvalidation.cache_key == repo_name)\ |
|
376 | 363 | .filter(CacheInvalidation.cache_active == False)\ |
|
377 | 364 | .scalar() |
@@ -379,7 +366,8 b' class ScmModel(BaseModel):' | |||
|
379 | 366 | return ret |
|
380 | 367 | |
|
381 | 368 | def _mark_invalidated(self, cache_key): |
|
382 |
""" Marks all occurences of cache to invaldation as already |
|
|
369 | """ Marks all occurrences of cache to invalidation as already | |
|
370 | invalidated | |
|
383 | 371 | |
|
384 | 372 | :param cache_key: |
|
385 | 373 | """ |
@@ -38,26 +38,26 b'' | |||
|
38 | 38 | <tr class="parity${cnt%2}"> |
|
39 | 39 | <td> |
|
40 | 40 | ## TYPE OF REPO |
|
41 |
%if repo['repo'] |
|
|
41 | %if repo['dbrepo'].repo_type =='hg': | |
|
42 | 42 | <img class="icon" title="${_('Mercurial repository')}" alt="${_('Mercurial repository')}" src="/images/icons/hgicon.png"/> |
|
43 |
%elif repo['repo'] |
|
|
43 | %elif repo['dbrepo'].repo_type =='git': | |
|
44 | 44 | <img class="icon" title="${_('Git repository')}" alt="${_('Git repository')}" src="/images/icons/giticon.png"/> |
|
45 | 45 | %else: |
|
46 | 46 | |
|
47 | 47 | %endif |
|
48 | 48 | |
|
49 | 49 | ## PRIVATE/PUBLIC REPO |
|
50 |
%if repo['repo'] |
|
|
50 | %if repo['dbrepo'].private: | |
|
51 | 51 | <img alt="${_('private')}" src="/images/icons/lock.png"/> |
|
52 | 52 | %else: |
|
53 | 53 | <img alt="${_('public')}" src="/images/icons/lock_open.png"/> |
|
54 | 54 | %endif |
|
55 | 55 | ${h.link_to(repo['name'],h.url('edit_repo',repo_name=repo['name']))} |
|
56 | 56 | |
|
57 |
%if repo['repo'] |
|
|
58 |
<a href="${h.url('summary_home',repo_name=repo['repo'] |
|
|
57 | %if repo['dbrepo'].fork: | |
|
58 | <a href="${h.url('summary_home',repo_name=repo['dbrepo'].fork.repo_name)}"> | |
|
59 | 59 | <img class="icon" alt="${_('public')}" |
|
60 |
title="${_('Fork of')} ${repo['repo'] |
|
|
60 | title="${_('Fork of')} ${repo['dbrepo'].fork.repo_name}" | |
|
61 | 61 | src="/images/icons/arrow_divide.png"/></a> |
|
62 | 62 | %endif |
|
63 | 63 | </td> |
@@ -119,24 +119,24 b'' | |||
|
119 | 119 | %for repo in c.user_repos: |
|
120 | 120 | <tr> |
|
121 | 121 | <td> |
|
122 |
%if repo['repo'] |
|
|
122 | %if repo['dbrepo'].repo_type =='hg': | |
|
123 | 123 | <img class="icon" title="${_('Mercurial repository')}" alt="${_('Mercurial repository')}" src="/images/icons/hgicon.png"/> |
|
124 |
%elif repo['repo'] |
|
|
124 | %elif repo['dbrepo'].repo_type =='git': | |
|
125 | 125 | <img class="icon" title="${_('Git repository')}" alt="${_('Git repository')}" src="/images/icons/giticon.png"/> |
|
126 | 126 | %else: |
|
127 | 127 | |
|
128 | 128 | %endif |
|
129 |
%if repo['repo'] |
|
|
129 | %if repo['dbrepo'].private: | |
|
130 | 130 | <img class="icon" alt="${_('private')}" src="/images/icons/lock.png"/> |
|
131 | 131 | %else: |
|
132 | 132 | <img class="icon" alt="${_('public')}" src="/images/icons/lock_open.png"/> |
|
133 | 133 | %endif |
|
134 | 134 | |
|
135 | 135 | ${h.link_to(repo['repo'].name, h.url('summary_home',repo_name=repo['repo'].name),class_="repo_name")} |
|
136 |
%if repo['repo'] |
|
|
137 |
<a href="${h.url('summary_home',repo_name=repo['repo'] |
|
|
136 | %if repo['dbrepo'].fork: | |
|
137 | <a href="${h.url('summary_home',repo_name=repo['dbrepo'].fork.repo_name)}"> | |
|
138 | 138 | <img class="icon" alt="${_('public')}" |
|
139 |
title="${_('Fork of')} ${repo['repo'] |
|
|
139 | title="${_('Fork of')} ${repo['dbrepo'].fork.repo_name}" | |
|
140 | 140 | src="/images/icons/arrow_divide.png"/></a> |
|
141 | 141 | %endif |
|
142 | 142 | </td> |
@@ -142,10 +142,10 b'' | |||
|
142 | 142 | <ul class="repo_switcher"> |
|
143 | 143 | %for repo in c.cached_repo_list: |
|
144 | 144 | |
|
145 |
%if repo['repo'] |
|
|
146 |
<li><img src="/images/icons/lock.png" alt="${_('Private repository')}" class="repo_switcher_type"/>${h.link_to(repo['repo'].name,h.url('summary_home',repo_name=repo['repo'].name),class_="%s" % repo['repo'] |
|
|
145 | %if repo['dbrepo'].private: | |
|
146 | <li><img src="/images/icons/lock.png" alt="${_('Private repository')}" class="repo_switcher_type"/>${h.link_to(repo['repo'].name,h.url('summary_home',repo_name=repo['repo'].name),class_="%s" % repo['dbrepo'].repo_type)}</li> | |
|
147 | 147 | %else: |
|
148 |
<li><img src="/images/icons/lock_open.png" alt="${_('Public repository')}" class="repo_switcher_type" />${h.link_to(repo['repo'].name,h.url('summary_home',repo_name=repo['repo'].name),class_="%s" % repo['repo'] |
|
|
148 | <li><img src="/images/icons/lock_open.png" alt="${_('Public repository')}" class="repo_switcher_type" />${h.link_to(repo['repo'].name,h.url('summary_home',repo_name=repo['repo'].name),class_="%s" % repo['dbrepo'].repo_type)}</li> | |
|
149 | 149 | %endif |
|
150 | 150 | %endfor |
|
151 | 151 | </ul> |
@@ -60,16 +60,16 b'' | |||
|
60 | 60 | <td> |
|
61 | 61 | <div style="white-space: nowrap"> |
|
62 | 62 | ## TYPE OF REPO |
|
63 |
%if repo['repo'] |
|
|
63 | %if repo['dbrepo'].repo_type =='hg': | |
|
64 | 64 | <img class="icon" title="${_('Mercurial repository')}" alt="${_('Mercurial repository')}" src="/images/icons/hgicon.png"/> |
|
65 |
%elif repo['repo'] |
|
|
65 | %elif repo['dbrepo'].repo_type =='git': | |
|
66 | 66 | <img class="icon" title="${_('Git repository')}" alt="${_('Git repository')}" src="/images/icons/giticon.png"/> |
|
67 | 67 | %else: |
|
68 | 68 | |
|
69 | 69 | %endif |
|
70 | 70 | |
|
71 | 71 | ##PRIVATE/PUBLIC |
|
72 |
%if repo['repo'] |
|
|
72 | %if repo['dbrepo'].private: | |
|
73 | 73 | <img class="icon" title="${_('private repository')}" alt="${_('private repository')}" src="/images/icons/lock.png"/> |
|
74 | 74 | %else: |
|
75 | 75 | <img class="icon" title="${_('public repository')}" alt="${_('public repository')}" src="/images/icons/lock_open.png"/> |
@@ -78,10 +78,10 b'' | |||
|
78 | 78 | ##NAME |
|
79 | 79 | ${h.link_to(repo['name'], |
|
80 | 80 | h.url('summary_home',repo_name=repo['name']),class_="repo_name")} |
|
81 |
%if repo['repo'] |
|
|
82 |
<a href="${h.url('summary_home',repo_name=repo['repo'] |
|
|
81 | %if repo['dbrepo'].fork: | |
|
82 | <a href="${h.url('summary_home',repo_name=repo['dbrepo'].fork.repo_name)}"> | |
|
83 | 83 | <img class="icon" alt="${_('fork')}" |
|
84 |
title="${_('Fork of')} ${repo['repo'] |
|
|
84 | title="${_('Fork of')} ${repo['dbrepo'].fork.repo_name}" | |
|
85 | 85 | src="/images/icons/arrow_divide.png"/></a> |
|
86 | 86 | %endif |
|
87 | 87 | </div> |
@@ -31,38 +31,38 b'' | |||
|
31 | 31 | <label>${_('Name')}:</label> |
|
32 | 32 | </div> |
|
33 | 33 | <div class="input-short"> |
|
34 |
%if c. |
|
|
34 | %if c.dbrepo.repo_type =='hg': | |
|
35 | 35 | <img style="margin-bottom:2px" class="icon" title="${_('Mercurial repository')}" alt="${_('Mercurial repository')}" src="/images/icons/hgicon.png"/> |
|
36 | 36 | %endif |
|
37 |
%if c. |
|
|
37 | %if c.dbrepo.repo_type =='git': | |
|
38 | 38 | <img style="margin-bottom:2px" class="icon" title="${_('Git repository')}" alt="${_('Git repository')}" src="/images/icons/giticon.png"/> |
|
39 | 39 | %endif |
|
40 | 40 | |
|
41 |
%if c. |
|
|
41 | %if c.dbrepo.private: | |
|
42 | 42 | <img style="margin-bottom:2px" class="icon" title="${_('private repository')}" alt="${_('private repository')}" src="/images/icons/lock.png"/> |
|
43 | 43 | %else: |
|
44 | 44 | <img style="margin-bottom:2px" class="icon" title="${_('public repository')}" alt="${_('public repository')}" src="/images/icons/lock_open.png"/> |
|
45 | 45 | %endif |
|
46 |
<span style="font-size: 1.6em;font-weight: bold;vertical-align: baseline;">${c.repo |
|
|
46 | <span style="font-size: 1.6em;font-weight: bold;vertical-align: baseline;">${c.repo.name}</span> | |
|
47 | 47 | %if c.rhodecode_user.username != 'default': |
|
48 | 48 | %if c.following: |
|
49 | 49 | <span id="follow_toggle" class="following" title="${_('Stop following this repository')}" |
|
50 |
onclick="javascript:toggleFollowingRepo(this,${c. |
|
|
50 | onclick="javascript:toggleFollowingRepo(this,${c.dbrepo.repo_id},'${str(h.get_token())}')"> | |
|
51 | 51 | </span> |
|
52 | 52 | %else: |
|
53 | 53 | <span id="follow_toggle" class="follow" title="${_('Start following this repository')}" |
|
54 |
onclick="javascript:toggleFollowingRepo(this,${c. |
|
|
54 | onclick="javascript:toggleFollowingRepo(this,${c.dbrepo.repo_id},'${str(h.get_token())}')"> | |
|
55 | 55 | </span> |
|
56 | 56 | %endif |
|
57 | 57 | %endif: |
|
58 | 58 | <br/> |
|
59 |
%if c. |
|
|
59 | %if c.dbrepo.fork: | |
|
60 | 60 | <span style="margin-top:5px"> |
|
61 |
<a href="${h.url('summary_home',repo_name=c. |
|
|
61 | <a href="${h.url('summary_home',repo_name=c.dbrepo.fork.repo_name)}"> | |
|
62 | 62 | <img class="icon" alt="${_('public')}" |
|
63 |
title="${_('Fork of')} ${c. |
|
|
63 | title="${_('Fork of')} ${c.dbrepo.fork.repo_name}" | |
|
64 | 64 | src="/images/icons/arrow_divide.png"/> |
|
65 |
${_('Fork of')} ${c. |
|
|
65 | ${_('Fork of')} ${c.dbrepo.fork.repo_name} | |
|
66 | 66 | </a> |
|
67 | 67 | </span> |
|
68 | 68 | %endif |
@@ -75,7 +75,7 b'' | |||
|
75 | 75 | <label>${_('Description')}:</label> |
|
76 | 76 | </div> |
|
77 | 77 | <div class="input-short"> |
|
78 |
${c. |
|
|
78 | ${c.dbrepo.description} | |
|
79 | 79 | </div> |
|
80 | 80 | </div> |
|
81 | 81 | |
@@ -86,11 +86,11 b'' | |||
|
86 | 86 | </div> |
|
87 | 87 | <div class="input-short"> |
|
88 | 88 | <div class="gravatar"> |
|
89 |
<img alt="gravatar" src="${h.gravatar_url(c. |
|
|
89 | <img alt="gravatar" src="${h.gravatar_url(c.dbrepo.user.email)}"/> | |
|
90 | 90 | </div> |
|
91 |
${_('Username')}: ${c. |
|
|
92 |
${_('Name')}: ${c. |
|
|
93 |
${_('Email')}: <a href="mailto:${c. |
|
|
91 | ${_('Username')}: ${c.dbrepo.user.username}<br/> | |
|
92 | ${_('Name')}: ${c.dbrepo.user.name} ${c.dbrepo.user.lastname}<br/> | |
|
93 | ${_('Email')}: <a href="mailto:${c.dbrepo.user.email}">${c.dbrepo.user.email}</a> | |
|
94 | 94 | </div> |
|
95 | 95 | </div> |
|
96 | 96 | |
@@ -99,8 +99,8 b'' | |||
|
99 | 99 | <label>${_('Last change')}:</label> |
|
100 | 100 | </div> |
|
101 | 101 | <div class="input-short"> |
|
102 |
${h.age(c.repo |
|
|
103 |
${_('by')} ${h.get_changeset_safe(c.repo |
|
|
102 | ${h.age(c.repo.last_change)} - ${c.repo.last_change} | |
|
103 | ${_('by')} ${h.get_changeset_safe(c.repo,'tip').author} | |
|
104 | 104 | |
|
105 | 105 | </div> |
|
106 | 106 | </div> |
@@ -128,7 +128,7 b'' | |||
|
128 | 128 | <label>${_('Download')}:</label> |
|
129 | 129 | </div> |
|
130 | 130 | <div class="input-short"> |
|
131 |
%if len(c.repo |
|
|
131 | %if len(c.repo.revisions) == 0: | |
|
132 | 132 | ${_('There are no downloads yet')} |
|
133 | 133 | %elif c.enable_downloads is False: |
|
134 | 134 | ${_('Downloads are disabled for this repository')} |
@@ -136,14 +136,14 b'' | |||
|
136 | 136 | [${h.link_to(_('enable'),h.url('edit_repo',repo_name=c.repo_name))}] |
|
137 | 137 | %endif |
|
138 | 138 | %else: |
|
139 |
${h.select('download_options',c.repo |
|
|
140 |
%for cnt,archive in enumerate(c.repo |
|
|
139 | ${h.select('download_options',c.repo.get_changeset().raw_id,c.download_options)} | |
|
140 | %for cnt,archive in enumerate(c.repo._get_archives()): | |
|
141 | 141 | %if cnt >=1: |
|
142 | 142 | | |
|
143 | 143 | %endif |
|
144 | 144 | <span class="tooltip" title="${_('Download %s as %s') %('tip',archive['type'])}" |
|
145 | 145 | id="${archive['type']+'_link'}">${h.link_to(archive['type'], |
|
146 |
h.url('files_archive_home',repo_name=c.repo |
|
|
146 | h.url('files_archive_home',repo_name=c.repo.name, | |
|
147 | 147 | fname='tip'+archive['extension']),class_="archive_icon")}</span> |
|
148 | 148 | %endfor |
|
149 | 149 | %endif |
@@ -155,8 +155,8 b'' | |||
|
155 | 155 | <label>${_('Feeds')}:</label> |
|
156 | 156 | </div> |
|
157 | 157 | <div class="input-short"> |
|
158 |
${h.link_to(_('RSS'),h.url('rss_feed_home',repo_name=c.repo |
|
|
159 |
${h.link_to(_('Atom'),h.url('atom_feed_home',repo_name=c.repo |
|
|
158 | ${h.link_to(_('RSS'),h.url('rss_feed_home',repo_name=c.repo.name),class_='rss_icon')} | |
|
159 | ${h.link_to(_('Atom'),h.url('atom_feed_home',repo_name=c.repo.name),class_='atom_icon')} | |
|
160 | 160 | </div> |
|
161 | 161 | </div> |
|
162 | 162 | </div> |
@@ -250,9 +250,9 b'' | |||
|
250 | 250 | YUE.on('download_options','change',function(e){ |
|
251 | 251 | var new_cs = e.target.options[e.target.selectedIndex]; |
|
252 | 252 | var tmpl_links = {} |
|
253 |
%for cnt,archive in enumerate(c.repo |
|
|
253 | %for cnt,archive in enumerate(c.repo._get_archives()): | |
|
254 | 254 | tmpl_links['${archive['type']}'] = '${h.link_to(archive['type'], |
|
255 |
h.url('files_archive_home',repo_name=c.repo |
|
|
255 | h.url('files_archive_home',repo_name=c.repo.name, | |
|
256 | 256 | fname='__CS__'+archive['extension']),class_="archive_icon")}'; |
|
257 | 257 | %endfor |
|
258 | 258 |
General Comments 0
You need to be logged in to leave comments.
Login now