#11650 closed defect (fixed)
Incorrect error message when BROWSER_VIEW permission revoked via TracFineGrainedPermissions
Reported by: | Ryan J Ollos | Owned by: | Jun Omae |
---|---|---|---|
Priority: | normal | Milestone: | 1.0.2 |
Component: | version control/browser | Version: | |
Severity: | normal | Keywords: | authzpolicy |
Cc: | Jun Omae | Branch: | |
Release Notes: |
Improve error message when no viewable repositories and accessing repository index. Fixed path in error message for Subversion and Mercurial repository when a |
||
API Changes: | |||
Internal Changes: |
Description
I noticed while evaluating the changes in #11646 that the error message is different when the user lack BROWSER_VIEW
vs when the permission is revoked using TracFineGrainedPermissions.
When the user lacks BROWSER_VIEW
:
When BROWSER_VIEW
is revoked through the following fine-grained permissions policy:
[repository:*@*] * = !BROWSER_VIEW
Attachments (3)
Change History (18)
by , 11 years ago
Attachment: | BrowserViewRevoked.png added |
---|
by , 11 years ago
Attachment: | NoBrowserView.png added |
---|
comment:1 by , 11 years ago
comment:2 by , 11 years ago
Milestone: | → 1.0.2 |
---|
comment:3 by , 10 years ago
The issue in #11662 was discovered while testing the changes in this ticket. It's not directly related.
follow-up: 7 comment:4 by , 10 years ago
The changes look good.
I stumbled on an issue not directly related. When viewing SVN repository repos1
at path /repos1
and not having the required permission, the message is:
When viewing Git repository repos2
at path /repos2
, the message is:
For the first message, /@48
should be displayed rather than @48
. I propose a change in log:rjollos.git:t11650.2.
follow-up: 10 comment:7 by , 10 years ago
Replying to rjollos:
For the first message,
/@48
should be displayed rather than@48
. I propose a change in log:rjollos.git:t11650.2.
Change committed to 1.0-stable in [12947], merged to trunk in [12948].
The issue would be fixed for MercurialPlugin by:
-
tracext/hg/backend.py
a b 588 588 self.repo = None 589 589 590 590 def normalize_path(self, path): 591 """Remove leading "/" (even at root)"""592 return path and path.strip('/') or ' '591 """Remove leading "/", except at root.""" 592 return path and path.strip('/') or '/' 593 593 594 594 def normalize_rev(self, rev): 595 595 """Return the full hash for the specified rev."""
The change would make normalize_path
for MercurialPlugin to be the same as normalize_path
for Git and Subversion. However, I'm concerned that this might break something since the comment says the behavior is intentional. I haven't found any issues with the change yet though.
comment:8 by , 10 years ago
I've rebased the proposed changes, jomae.git@t11650.3. I'll commit it tonight.
comment:9 by , 10 years ago
Release Notes: | modified (diff) |
---|
The jomae.git@t11650.3 has been committed in [13010] and merged to trunk in [13011].
comment:10 by , 10 years ago
Replying to rjollos:
Replying to rjollos:
For the first message,
/@48
should be displayed rather than@48
. I propose a change in log:rjollos.git:t11650.2.Change committed to 1.0-stable in [12947], merged to trunk in [12948].
The issue would be fixed for MercurialPlugin by: […]
The change would make
normalize_path
for MercurialPlugin to be the same asnormalize_path
for Git and Subversion. However, I'm concerned that this might break something since the comment says the behavior is intentional. I haven't found any issues with the change yet though.
I think the change is safe, committed as [5003d900/mercurial-plugin].
comment:11 by , 10 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
comment:12 by , 10 years ago
Owner: | set to |
---|---|
Release Notes: | modified (diff) |
comment:13 by , 10 years ago
Release Notes: | modified (diff) |
---|
comment:14 by , 10 years ago
With a single default repository defined either through the repositories admin page or through trac.ini, No viewable repositories is displayed when navigating to /browser
.
[repositories] .dir = /home/user/Workspace/tracdev/repos/tracdev .type = sv
If the repository is given a name, then the repository index is shown:
[repositories] trac.dir = /home/user/Workspace/tracdev/repos/tracdev trac.type = svn
I haven't yet tested the behavior prior to the changes in this ticket, but I suspect we may have a regression.
by , 10 years ago
Attachment: | RepositoryIndex.png added |
---|
comment:15 by , 10 years ago
I apologize. comment:7 was due to an AuthzPolicy
that I didn't realize was active. Everything is working correctly!
The repository browser cannot determine whether
BROWSER_VIEW
is revoked from all repositories or one. Currently, if the policy is used, it behaves as well with no viewable repositories. e.g. repositories are not defined or hidden.However, "No node /" message doesn't seem to be user-friendly. How about showing "No viewable repositories" in that case? See jomae.git@t11650.