On Fri, 2009-07-10 at 10:55 -0400, Joshua Brindle wrote: > Chad Sellers wrote: > > On 7/9/09 4:48 PM, "Daniel J Walsh"<dwalsh@xxxxxxxxxx> wrote: > > <snip> > >> A couple of other problems with including policy with each rpm. How do you > >> handle different packaging. MLS, Targeted, minimal. > >> > > That is a problem we'll have to solve, but I don't think it will be too > > difficult. We could easily provide an option to the %policy directive that > > could direct rpm to use a particular policy store. > > > >> If every package includes policy then we need to rely on the package > >> maintainer to write good secure policy. You have to realize that the goal of > >> a package maintainer is to make the tool run, not necessarily to make sure it > >> is secure or that other componants of the OS integrate well. > >> > >> ftp sometimes need to read any file on the OS, so I will add > >> files_read_all(ftp_t) > >> > >> Now getting the few packages that ship their own policy to work better and the > >> selinux-policy package to work better would be great. > >> > > That's our initial goal. We want better infrastructure for the packages that > > exist today. Policy can transition into other application packages if and > > when it makes sense. If a package maintainer has no business touching > > policy, then they will not be forced to do so. > > > >> How about fixing things like semanage command > >> > >> semanage fcontext .... > >> semanage ports .... > >> restorecon ... > >> > >> > >> Removal of policy packages is a huge problem in that once a type is removed > >> you end up with mislabeled files that can not be indentified. > >> > > Agreed, and we've talked about some potential solutions to this problem that > > do not involve automatic relabeling. This is a likely next step for this > > work after the initial RPM integration. > > > > The more I think about this the less I like the idea of uninstalling policy. > Even if we retain the labels (eg., save the namespace, ditch the rules) the > files are inaccessible. Leaving the policy ensures that admins/backup > apps/whatever can do whatever they could do before with the files, even if the > associated app is gone. > The same potential problems exist whenever policy modules (specifically types) are removed. Policy packages would be different from the current usage in two ways: 1) Policy modules would be removed when their associated application is not installed, whereas currently policy modules are probably never removed. 2) The removal would be automatic and right away, whereas currently an admin could take other actions before manually removing the policy module. So policy packages would be more likely to expose the problems that currently exist. > >> You do not know where these files are and you need to relabel the entire > >> machine to make sure there are no longer any mislabeled files around. > >> > >> When you update policy you need to run a diff between the old file context and > >> the new and run a recusive restorecon on the diff. fixfiles -C > >> PREVIOUS_FILECONTEXT relabel does this for you, but every rpm transaction that > >> does a policy modules update needs to run this at the completion of the > >> transaction. As well as squirrel away the previous file context before the > >> transaction. > > > > Running fixfiles -C after any rpm transaction that modifies policy seems > > reasonable (as long as there's an option to disable this behavior for those > > that don't like automatic relabeling). > > > > Its alot worse than that. What about files on backup drives? Offline drives? > transient files that will get relabeled to something inappropriate? I'm not > confortable relabeling databases with potentially sensitive data to var_lib_t > because mysql was uninstalled. > The argument seems to be for removing the ability to remove modules. It would be the roach motel style of policy management. > -- > This message was distributed to subscribers of the selinux mailing list. > If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with > the words "unsubscribe selinux" without quotes as the message. -- James Carter <jwcart2@xxxxxxxxxxxxx> National Security Agency -- This message was distributed to subscribers of the selinux mailing list. If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with the words "unsubscribe selinux" without quotes as the message.