On Mon, 2006-04-24 at 16:08 +0200, Olivier Galibert wrote:
> On Mon, Apr 24, 2006 at 02:54:10PM +0200, Arjan van de Ven wrote:
> >
> > > While that may be true[1], it gets a little annoying when broken is
> > > meant to be synonymous to "not the SELinux model". Especially since
> > > there are aspects where SELinux' security can be considered broken,
> > > complexity being one of them, crappy failure modes being another,
> > > handling of new files a third, handling of namespaces a fourth.
> >
> > while I agree with the first three arguments, handling of namespaces
> > isn't fundamental SELinux weakness.
>
> I'm not sure. It's linked to the "new files" problem.
> Object-labelling security (be it inodes, attributes, whatever) are
> good to protect specific objects, but it sucks on two points:
> - new objects can have an incorrect by-default labels
This generally indicates a problem in policy or the application that
needs to be fixed. It doesn't mean that object labeling is itself
problematic, anymore than the existing owner and mode information in the
inode is inherently problematic.
> - applications don't address objects directly, but by one of their
> names, the paths
>
> Path-based security does not protect objects, it protects what you
> access through the names, whether there are associated objects or not.
> So in practice path security protects the behaviour of applications
> against mucking with the filesystem, while object labelling protects
> the contents of the files. They're complementary, they need each
> other in practice.
Object labeling achieves both. It doesn't require a path-based
mechanism in the kernel.
> It's more robust at protecting objects contents, it's less robust at
> protecting application behaviour. A lot like GR and QM, the best
> model is somewhere in the middle :-)
How is it less robust? I haven't seen such an argument.
> For now if I follow correctly the LSM interfaces are decent for
> object-based policy implementations, and not decent for path-based
> ones.
Yes.
> Maybe the object-based policy hooks should be evolving in the
> direction of SELinux' comfort, and additional hooks specifically for
> path-based policy added, probably along the lines of what AppArmor
> needs. Then hopefully someday someone will build a security system
> that uses the best features from both. But refusing path-based policy
> in the kernel for religious reasons would be annoying.
I don't think it is religious - it has to do with the kernel's internal
model and what makes sense for the kernel to implement. And the
question is not whether policy can/should be path-based; it is whether
the kernel mechanism should be path-based. And further, whether even
such a path-based kernel mechanism should be done in the manner in which
AppArmor does it. Bad example, I suppose, but consider inotify - does
it regenerate pathnames in the kernel, and use those pathnames in its
own mechanism?
--
Stephen Smalley
National Security Agency
-
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]