Bug #162542 - When dropping privileges for FEATURES=userpriv,
authorZac Medico <zmedico@gentoo.org>
Thu, 10 Jan 2008 23:02:01 +0000 (23:02 -0000)
committerZac Medico <zmedico@gentoo.org>
Thu, 10 Jan 2008 23:02:01 +0000 (23:02 -0000)
automatically detect permission problems with CCACHE_DIR and
recursively adjust permissions only when necessary.

svn path=/main/trunk/; revision=9160

pym/portage/__init__.py

index c56286069fcbace9b1d0c246f451bace29d3743d..4a9283ab234e49bf59654b9463e255e8e7ab045f 100644 (file)
@@ -4067,6 +4067,11 @@ def prepare_build_dirs(myroot, mysettings, cleanup):
        dirmode  = 02070
        filemode =   060
        modemask =    02
+       restrict = mysettings.get("PORTAGE_RESTRICT","").split()
+       from portage.data import secpass
+       droppriv = secpass >= 2 and \
+               "userpriv" in mysettings.features and \
+               "userpriv" not in restrict
        for myfeature, kwargs in features_dirs.iteritems():
                if myfeature in mysettings.features:
                        basedir = mysettings[kwargs["basedir_var"]]
@@ -4083,7 +4088,13 @@ def prepare_build_dirs(myroot, mysettings, cleanup):
                                        # Generally, we only want to apply permissions for
                                        # initial creation.  Otherwise, we don't know exactly what
                                        # permissions the user wants, so should leave them as-is.
-                                       if modified or kwargs["always_recurse"]:
+                                       droppriv_fix = False
+                                       if droppriv:
+                                               st = os.stat(mydir)
+                                               if st.st_gid != portage_gid or \
+                                                       not stat.S_IMODE(st.st_mode) & dirmode:
+                                                       droppriv_fix = True
+                                       if modified or kwargs["always_recurse"] or droppriv_fix:
                                                if modified:
                                                        writemsg("Adjusting permissions recursively: '%s'\n" % mydir,
                                                                noiselevel=-1)