On Oct 04, 2007, at 21:44:02, Eric W. Biederman wrote:
What we want from the LSM is the ability to say -EPERM when we can
clearly articulate that we want to disallow something.
This sort of depends on perspective; typically with security
infrastructure you actually want "... the ability to return success
when we can clearly articulate that we want to *ALLOW* something".
File permissions work this way; we don't have a list of forbidden
users attached to each file, we have an owner, a group, and a mode
representing positive permissions. With that said in certain high-
risk environments you need something even stronger that cannot be
changed by the "owner" of the file, if we don't entirely trust them,
SElinux is not all encompassing or it is generally incomprehensible
I don't know which. Or someone long ago would have said a better
way to implement containers was with a selinux ruleset, here is a
selinux ruleset that does that. Although it is completely possible
to implement all of the isolation with the existing LSM hooks as
Serge showed.
The difference between SELinux and containers is that SELinux (and
LSM as a whole) returns -EPERM to operations outside the scope of the
subject, whereas containers return -ENOENT (because it's not even in
the same namespace).
We also have in the kernel another parallel security mechanism (for
what is generally a different class of operations) that has been
quite successful, and different groups get along quite well, and
ordinary mortals can understand it. The linux firewalling code.
Well, I wouldn't go so far as the "ordinary mortals can understand
it" part; it's still pretty high on the obtuse-o-meter.
The linux firewalling codes has hooks all throughout the networking
stack, just like the LSM has hooks all throughout the rest of linux
kernel. There is a difference however. The linux firewalling code
in addition to hooks has tables behind those hooks that it
consults. There is generic code to walk those tables and consult
with different kernel modules to decide if we should drop a
packet. Each of those kernel modules provides a different
capability that can be used to generate a firewall.
This is almost *EXACTLY* what SELinux provides as an LSM module. The
one difference is that with SELinux some compromises and restrictions
have been made so that (theoretically) the resulting policy can be
exhaustively analyzed to *prove* what it allows and disallows. It
may be that SELinux should be split into 2 parts, one that provides
the underlying table-matching and the other that uses it to provide
the provability guarantees. Here's a direct comparison:
netfilter:
(A) Each packet has src, dst, port, etc that can be matched
(B) Table of rules applied sequentially (MATCH => ACTION)
(C) Rules may alter the properties of packets as they are routed/
bridged/etc
selinux:
(A) Each object has user, role, and type that can be matched
(B) Table of rules searched by object parameters (MATCH => allow/
auditallow/transition)
(C) Rules may alter the properties of objects through transition
rules.
If there are areas where people are confused about SELinux, think it
may be improved, etc, we would be *GLAD* to hear it. I'm currently
struggling to find the time between a hundred other things to finish
a script I offered to Casey Schaufler a month and a half ago which
generated an SELinux policy based on a SMACK ruleset.
So I propose that if people want to work towards a one true linux
solution for additional security checks, then they should look
towards the linux firewalling code. It works and it seems to very
nicely allow cooperations between different groups. For the people
who will scream mixing security models causes problems, the answer
is simple recommend users don't set up their policies that way.
Actually the one thing which really frustrates me about the Linux
firewalling code is that you cannot selectively apply various
transformation phases, they are automatically applied for you. I
have had a couple very-transparent-routing-firewalling-bridging
scenarios where I wished I could run the bridging phase, compare-and-
change the result, and then run the bridging phase again to forward
the packet elsewhere. For example if I was to set up a diverted
ethernet port I would need to apply the bridging code, compare the
destination port against the selected diverted port and change the
MAC address, then reapply the bridging code. To mirror you would
also need a phase which could create multiple clones of packets and
conditionalize rules based on which of the copies it was.
I'm not yet annoyed enough to go implement an iptables like
interface to the LSM enhancing it with more generic mechanism to
make the problem simpler, but I'm getting there. Perhaps next time
I'm bored.
I think a fair amount of what we need is already done in SELinux, and
efforts would be better spent in figuring out what seems too
complicated in SELinux and making it simpler. Probably a fair amount
of that just means better tools.
Cheers,
Kyle Moffett
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]