Re: Socket and inode label consistency

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On Aug 27, 2008, at 11:49 AM, Paul Moore wrote:
On Wednesday 27 August 2008 7:57:34 am Stephen Smalley wrote:
On Tue, 2008-08-26 at 20:50 -0400, Trent Jaeger wrote:
Hi,

I see on the Kernel Development To Do list at http://
selinuxproject.org/page/Kernel_Development that the following task
is identified:

"Full APIs for getting and setting security contexts of sockets and
IPC objects. Ensure that socket context is kept consistent on
socket inode and sock structures when changed."

We are being bitten by this now, so I am wondering if anyone is
working on it or wishes to discuss how to proceed.  We would be
interested in addressing this issue.

I don't know of anyone working on it, but we are interested in it.

It is something that has been on my todo list for some time but it is 
stuck with such a low priority that I haven't been able to make any 
progress on it.  If you've got time to work on it, I would be very 
happy :)

As I recall, you can get and set the socket inode label via fgetxattr
and fsetxattr but the struct sock label isn't accessible from
userspace (except via getpeercon, and then only for the peer).  I
think you'd need to add a .setxattr method to the socket_file_ops and
have them call into the LSM interface to update the sock information
(as well as continuing to update the socket inode info).

There would also need to be some work done to ensure that all the 
outbound labeled networking stuff is updated when the socket's label is 
changed via the xattr operations.  Right now there is no way (at least 
not that I know of) to change the label of an existing socket so we 
don't have to worry about that problem.

I also wonder about changing the label of a socket while it is 
connected, probably not a big issue for dgram sockets but I think it 
could get pretty strange for stream sockets.

Hi,

What we want is to create a socket within the context of a multilevel secure process.  For example, if the process has an MLS range of s0-s1, we may want an s0 or s1 socket.  

Thus, in theory, we should be able to avoid dealing with context changes on connected sockets and such.  Once the socket goes into any use, it cannot be relabeled.

I am not sure that setxattr will work as this is an inode operation, and I do not see a reference from an inode to an associated socket.  

Originally, I was thinking of setsockopt, but I agree that it would be nice to deal with it via the file interface, like fsetfilecon.

Thoughts?

Regards,
Trent.
----------------------------------------------
Trent Jaeger, Associate Professor
Pennsylvania State University, CSE Dept
346A IST Bldg, University Park, PA 16802
Ph: (814) 865-1042, Fax: (814) 865-3176




[Index of Archives]     [Selinux Refpolicy]     [Linux SGX]     [Fedora Users]     [Fedora Desktop]     [Yosemite Photos]     [Yosemite Camping]     [Yosemite Campsites]     [KDE Users]     [Gnome Users]

  Powered by Linux