Re: New LSM security operation
From: Serge E. Hallyn
Date: Thu Jul 12 2007 - 14:17:23 EST
Quoting Zeus Gómez Marmolejo (zeus@xxxxxxxxxxx):
> Hi people,
>
> I've looked around on how to hide inodes in a Linux filesystem but
> surprisingly the kernel lacks this functionality. It would be desirable
> for me to add an ACL to a file in order not to be seen in the directory
> contents but only for some users.
>
> Some Selinux experts point out that the correct way to do this is via
> poly-instantiated directories such as /tmp or /var/tmp, so each user
> "view" his own version of this directory. But that's not what I want,
> for example in /etc, I would want to hide some directories or files for
> some users. I don't want a whole /etc instantiation for each user logged in.
>
> Also, there is a patch called LIDS that does the thing, but patching the
> whole kernel and adding much extra functionality such as intrussion
> detection system as it is. Some rootkits -like adore- also can hide
> inodes, but changing the owner to an uid that the kernel module hides
> from the system call. I don't thing this is a good approach...
>
> For me, the correct way to achieve this is to add an extra op in the
> "security_operations" struct, as an inode operation. With this, a
> Mandatory Access Control system that uses LSM such as SELinux can add
> some policies on the "list" file access vector.
That's how it is often done elsewhere, but (at least until now) the
correct way to achieve this in Linux is to make use of either
per-process namespaces or chroots. For example, either create custom fs
trees for each user under /share/ and chroot user hallyn under /share/hallyn
upon login, or, upon login, create a new mounts namespace and massage
the fs tree there.
For persistant filesystems, you can of course keep custom versions of
the filesystems in hidden directories. I.e. under /tmp/ you could
keep /tmp/.priv/hallyn, and, when hallyn logs in, do
mount --bind /tmp/.priv/hallyn /tmp
or if you're going the /share route, just do
mount --bind /share/hallyn/tmp/.priv/hallyn /share/hallyn/tmp
while setting up your trees after boot.
For procfs and sysfs, the containers (specifically process id namespaces
and network namespaces) are starting some of the work to support
showing only authorized data to containers.
-serge
> So, I'd call this hook in the vfs_readdir() syscall just after the "file
> <http://lxr.linux.no/ident?i=file>->f_op->readdir()" -the particular
> filesystem readdir()- and walk through the list to ask for each inode if
> it has permission to be "listed" in that directory. Then, the MAC system
> can handle the grant or deny permission per inode, and then return the
> "modified" list to userspace.
>
> I'm not sure if this is the correct way, or maybe it adds to much
> overhead to the "ls" command, but I'd like to hear some opinions, I can
> try to code it and summit a patch...
>
> Thanks for your answer,
>
> Zeus Gómez.
> PS. Please, include me in the CC if you reply this message.
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/