On Fri, 2008-10-17 at 15:39 -0400, Stephen Smalley wrote: > I don't follow the above. First, the CAP_SETUID capability controls the > ability to use set*uid() system calls, not to execute setuid binaries > (aside from a special case for shared state). Second, if some other > confined domain executes a setuid binary created by this user, it is > still limited by the permissions granted to that original confined > domain as far as SELinux is concerned. He's saying there are almost 200 domains that can run setuid apps. Limiting the number of domains that can create new setuid apps limits the number of places that these domains can go. Clearly they are all still confined to their domain and whatever it allows, but allowing them to gain root priveledges may give them the ability to attack other parts of the system normally controlled by dac. This certainly doesn't lessen the MAC confinement. Lets assume an audited system in which we are certain the only suid app untrusted users are allowed to run is ping. So the users have the right to run suid apps. They are protected from each other by DAC. Confined webadmin writes a program which is clears out other users public_html when they get a spurious DMCA takedown notice. He then (because he is a lazy bumbling idiot) makes his script suid so he does not have to go into his confined webadmin account constantly to delete users webpages. Normal DAC protects user2 from being attacked by user1. Because of the bumbling incompetance of confined webadmin user1 can now use this setuid app to do things which he is allow by selinux policy but denied by normal DAC permissions. Why did webadmin need to make a setuid app to begin with? file caps are already protected by CAP_SETFCAP. Lets assume system policy says that su should not be setuid. Should the webadmin really be allowed to easily override that system policy because he wants to use su - to get to his confined domain instead of sudo? She bumbling idiot really be allowed to say add o+x to su - when the system policy only really wanted group wheel to be able to run su? Should the bumbling idiot be able to remove the suid flag from a program and not be able to fix it? I think there are some real gains that can be made by limiting how confined admins or untrusted users can deal with suid apps. I'd probably be inclined to add changing the uid/gid/other things that clear setuid to be things which require this permission. I don't see a reason to allow my webadmin to chown su to himself... -Eric -- This message was distributed to subscribers of the selinux mailing list. If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with the words "unsubscribe selinux" without quotes as the message.