b0c1077c34
On Tue, 2009-08-11 at 08:12 -0400, Daniel J Walsh wrote: > On 08/10/2009 04:12 PM, Stephen Smalley wrote: > > On Mon, 2009-08-10 at 16:03 -0400, Stephen Smalley wrote: > >> On Mon, 2009-08-10 at 11:13 -0400, Daniel J Walsh wrote: > >>> Currently in F12 if you have file systems that root can not read > >>> > >>> # restorecon -R -v /var/lib/libvirt/ > >>> Can't stat directory "/home/dwalsh/.gvfs", Permission denied. > >>> Can't stat directory "/home/dwalsh/redhat", Permission denied. > >>> > >>> After patch > >>> > >>> # ./restorecon -R -v /var/lib/libvirt/ > >> > >> But if you were to run > >> ./restorecon -R /home/dwalsh > >> that would try to descend into .gvfs and redhat, right? > >> > >> I think you want instead to ignore the lstat error if the error was > >> permission denied and add the entry to the exclude list so that > >> restorecon will not try to descend into it. It is ok to exclude a > >> directory to which you lack permission. Try this: > > > > Also, why limit -e to only directories? Why not let the user exclude > > individual files if they choose to do so? In which case we could drop > > the mode test altogether, and possibly drop the lstat() call altogether? > > Or if you truly want to warn the user about non-existent paths, then > > take the lstat() and warning to the 'e' option processing in main() > > instead of doing it inside of add_exclude(). > > > I agree lets remove the directory check and warn on non existing files. Does this handle it correctly for you? Remove the directory check for the -e option and only apply the existence test to user-specified entries. Also ignore permission denied errors as it is ok to exclude a directory or file to which the caller lacks permission. Signed-off-by: Stephen Smalley <sds@tycho.nsa.gov> |
||
---|---|---|
.. | ||
Makefile | ||
restorecon.8 | ||
setfiles.8 | ||
setfiles.c |