MAC policies and shared hosting

Borja Marcos BORJAMAR at SARENET.ES
Wed May 3 13:49:42 UTC 2006


Hello,

I've been looking at the different MAC modules available and how they  
cold help to implement a less insecure than usual shared hosting web  
server.

I've not been able to come up with a suitable configuration, looking  
at mac_bsdextended, mac_biba and mac_mls, but I think that a MAC  
module with the following policies could be very useful for such an  
environment. Have I missed anything? Has something similar been done?

The module would (roughly) work as follows:

Defining security levels in a similar way to mac_mls or mac_biba,

we define a range of uids as sysctl variables to be used as  
"compartiments". For example,

mac.mac_uids.lowuid
mac.mac_uids.highid

And it would be implemented so that:

Below a given security level, (mac.mac_uids.enforce_below)

- Any operation of a subject with uid x (between lowuid and highuid)  
on an object with uid y (between lowuid and highuid) would fail.

- A subject with a given security level could not modify an object  
with a higher security level.

This, combined with a chroot tree would (I think) be much better than  
the typical solutions available. The webserver process would be  
launched as a low-security subject, and it is assumed that it would  
make a setuid() before launching a CGI process. And perhaps it  
wouldn't be so hard to modify an existing webserver so that it  
changed the uid when serving a page associated with a virtual server,  
adding a uid parameter to virtual servers.

What do you think? Ideas? (This is only a quick and dirty idea)







Borja.



More information about the freebsd-security mailing list