Mercurial > hg-stable
changeset 48879:6b10151b9621 stable 6.1.3
narrow_widen_acl: enforce narrowacl in narrow_widen (SEC)
Reviewer note: this was sent by the author as a simple bugfix, but can be
considered a security patch, since it allows users to access things outside
of the ACL, hence the (SEC) prefix.
However, this affects the `narrow` extention which is still marked as
experimental and has relatively few users aside from large companies with
their own security layers on top from what we can gather.
We feel (Alphare: or at least, I feel) like pinging the packaging list is
enough in this case.
author | Sandu Turcan <idlsoft@gmail.com> |
---|---|
date | Tue, 03 May 2022 21:44:30 -0400 |
parents | 201222849987 |
children | 985f2901aee0 |
files | hgext/narrow/narrowwirepeer.py tests/test-narrow-acl.t |
diffstat | 2 files changed, 42 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/hgext/narrow/narrowwirepeer.py Mon May 30 11:52:31 2022 +0200 +++ b/hgext/narrow/narrowwirepeer.py Tue May 03 21:44:30 2022 -0400 @@ -10,6 +10,7 @@ from mercurial import ( bundle2, error, + exchange, extensions, hg, narrowspec, @@ -86,6 +87,11 @@ newincludes = splitpaths(newincludes) oldexcludes = splitpaths(oldexcludes) newexcludes = splitpaths(newexcludes) + + # enforce narrow acl if set + if repo.ui.has_section(exchange._NARROWACL_SECTION): + exchange.applynarrowacl(repo, {'includepats': newincludes}) + # validate the patterns narrowspec.validatepatterns(set(oldincludes)) narrowspec.validatepatterns(set(newincludes))
--- a/tests/test-narrow-acl.t Mon May 30 11:52:31 2022 +0200 +++ b/tests/test-narrow-acl.t Tue May 03 21:44:30 2022 -0400 @@ -41,3 +41,39 @@ $ hg -R narrowclone1 tracked I path:f1 I path:f2 + +Narrow should not be able to widen to include f3 + $ hg -R narrowclone1 tracked --addinclude f3 + comparing with http://localhost:$HGPORT1/ + searching for changes + abort: The following includes are not accessible for test: ['path:f3'] + [255] + $ ls -A -1 narrowclone1 | sort + .hg + f1 + f2 + $ hg -R narrowclone1 tracked + I path:f1 + I path:f2 + +Narrow should allow widen to include f2 + $ hg -R narrowclone1 tracked --removeinclude f2 > /dev/null + $ hg -R narrowclone1 tracked + I path:f1 + $ ls -A -1 narrowclone1 | sort + .hg + f1 + $ hg -R narrowclone1 tracked --addinclude f2 + comparing with http://localhost:$HGPORT1/ + searching for changes + adding changesets + adding manifests + adding file changes + added 0 changesets with 1 changes to 1 files + $ hg -R narrowclone1 tracked + I path:f1 + I path:f2 + $ ls -A -1 narrowclone1 | sort + .hg + f1 + f2