Re: libsemanage.semanage_install_active: error during semodule -n -v -b base.pp -s refpolicy

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

 



Stephen Smalley wrote:
On Fri, 2008-06-13 at 16:16 -0400, Vikram Ambrose wrote:
Stephen Smalley wrote:
On Fri, 2008-06-13 at 15:31 -0400, Vikram Ambrose wrote:
Stephen Smalley wrote:
On Fri, 2008-06-13 at 15:11 -0400, Vikram Ambrose wrote:
Joshua Brindle wrote:
Vikram Ambrose wrote:
Stephen Smalley wrote:
On Thu, 2008-06-12 at 14:51 -0400, Vikram Ambrose wrote:
Stephen Smalley wrote:
On Thu, 2008-06-12 at 13:57 -0400, Vikram Ambrose wrote:
Stephen Smalley wrote:
On Thu, 2008-06-12 at 13:35 -0400, Vikram Ambrose wrote:
Stephen Smalley wrote:
On Thu, 2008-06-12 at 10:43 -0400, Vikram Ambrose wrote:
During the "make load" procedure with refpolicy, the semodule
command fails, so I tried it manually and I see this error.

root@ubuntu:/home/vikram/refpolicy-ac# semodule -b
/usr/share/selinux/refpolicy/base.pp -s refpolicy -v -n
Attempting to install base module
'/usr/share/selinux/refpolicy/base.pp':
Ok: return value of 0.
Committing changes:
libsemanage.semanage_install_active: setfiles returned error
code 1. (No such file or directory).
whereis setfiles

setfiles and the rest of the SELinux "toolchain" was all built
from svn and placed into /hone/testing/root
root's environment has PATH that contains /home/testing/root/bin
as well as LD_LIBRARY_PATH to /home/testing/root/lib

Does libsemanage have a hard coded path to setfiles?
Yes, although it can be overridden via /etc/selinux/semanage.conf.
Add something like:
[setfiles]
path = /path/to/setfiles
[end]

I just noticed the hard coded path in conf-parser.y
Is there a way of doing the above with a generic rule to all of the
selinux toolchain and not specifically to "setfiles" as shown above?
Not presently; it wasn't really intended for an alternate root
mechanism
(and apparently doesn't work for it anyway, as you have found).

And specifying each and every tool individual is not possible i suppose?
There are only two helpers that are executed by default, setfiles and
load_policy, and you can specify them both, using the same syntax but
different section keyword.

...
Adding that to semanage.conf produce an almost obvious error "
error while loading shared libraries: libsepol.so.0: cannot open
shared object file: No such file or directory"

what sort of environment is libsemanage using to execute setfiles?
libsepol and friends are in LD_LIBRARY_PATH
Ah, semanage_exec_prog() passes a NULL environ to execve().

Can this be rectified?
Even if we changed the code, the policy normally won't allow passing of
LD_LIBRARY_PATH and the like across a domain transition (noatsecure
permission to disable setting of AT_SECURE auxv flag), and setfiles and
load_policy typically run in their own domains.  Although you can
certainly customize policy and the code for your particular needs.

I think this takes us to the "run it in a chroot environment" scenario
if you don't want to install the libraries and programs to your system
directories.  I'm not entirely sure what your goal is here though - you
seem ok with installing the policy files to system directories.
Your last remark there is rather confusing to me. You seem to suggest
that "installing the policy files to system directories" is an option
I have been given, and as such chosen to do so. To my knowledge the
entire toolchain is hard coded to /etc/selinux and as such not
possible to provide a /different/syconfig/path. How is it that I go
about installing selinux and its configuration to a non "system
directory", yet "system wide" path such as /security or /selinux or
/seconfig etc..?
Well, yes, that's true.  Running it chroot'd is the only way right now
to do that.  Which would also resolve your problem with setfiles.

The other approach would be to change libselinux to support an alternate
root setting via some mechanism, but we have to be careful to not give
undue influence to callers where it isn't warranted, of course.

I added extern char **environ, and passed in environ to execve,  i also
added some printfs to see what was being passed into setfiles...

root@ubuntu:/home/vikram/refpolicy-ac# semodule -b
/usr/share/selinux/refpolicy/base.pp -s refpolicy -v
Attempting to install base module '/usr/share/selinux/refpolicy/base.pp':
Ok: return value of 0.
Committing changes:
e->path=/home/vikram/root/bin/setfiles
arg[0] = /home/vikram/root/bin/setfiles
arg[1] = (null)
usage:  /home/vikram/root/bin/setfiles [-dnpqvW] [-o filename] [-r
alt_root_path ] spec_file pathname...
usage:  /home/vikram/root/bin/setfiles -c policyfile spec_file
usage:  /home/vikram/root/bin/setfiles -s [-dnqvW] [-o filename ] spec_file
libsemanage.semanage_install_active: setfiles returned error code 1.

Why is setfiles being passed no arguments?

you need to add:

args = -q -c $@ $<

to the setfiles block in semanage.conf

could execve be changed to execvp? this way a hard coded path is not necessary.
I can write a patch?
But then the caller can influence the path and the environment.
And that presumes that setfiles and load_policy will always be in the
path of the caller of libsemanage.

understood. however the scope of the application's capabilities are limited by the user's unix permissions right? ie a regular user can make his own policy and store it in his home directory, maybe even with a hacked version of semodule, but at the end of the day the policy cannot be put into kernel memory by a regular user. Well thats how i understand it as.
We don't necessarily want the process (in this case your shell) that
invoked semodule to be able to arrange conditions to trick libsemanage
into executing a different helper of its choosing or to pass environment
settings to that helper that would enable the calling process to
control/influence it.  Not so critical for setfiles per se, as that is
only doing a validity check on the file_contexts configuration, but more
of a concern for the optional policy checkers/verifiers that can be
enabled via semanage.conf.

The helper applications dont read environment variables, do they?
And however misconfigure the userspace tool maybe kernel security is in place to protect the system.

Yes we "open the door" to the environment, but the tools executed by libsemanage dont do any harm, unless run as super user. but if you cant trust super-user then who can you trust?

Or maybe i just dont understand, Could you perhaps give a use case of how using execvp to allow the helper app to access the environment is a security risk?

See for example:
http://www.dwheeler.com/secure-programs/Secure-Programs-HOWTO/environment-variables.html

It isn't merely about explicit access of the environment by a helper
application, but rather the automatic use of environment settings by the
dynamic linker and by glibc in a way that affects security.  If a less
trusted caller is permitted to invoke semodule and can control the path
by which helpers it executes runs or the dynamic loader search path or
preload settings, then it can redirect execution to code of its
choosing.

Your comment about the superuser being trusted is missing the point; one
of the features of SELinux is the ability to limit each process/program
to least privilege whether superuser or not.

Now, it is true that in a normal configuration, semodule and the helpers
run in their own domains, and thus the glibc sanitization of the
environment upon a domain transition should suffice.  In your case I
presume this doesn't happen because you are installing semodule and the
helpers to a private directory and they are not being labeled with their
own executable type as a result.

However, it seems contrary to secure programming practice to open the
door unnecessarily, and I'm not sure it is even necessary in your case.
It sounds like all you really need/want is a way to suppress running of
setfiles altogether. That shouldn't be hard.
During the semodule -b -s command, the need to run setfiles is for what? Perhaps like you said i can just short that out altogether. i only need the build/install functionality of semodule, setting file contexts and loading the policy i would rather do manually, instead of libsemanage calling execve.

The execution of setfiles by libsemanage is merely to check the validity
of the file_contexts file against the policy.

You can effectively disable the use of setfiles there just by putting
the following in your /etc/selinux/semanage.conf file:
[setfiles]
path = /bin/true
[end]

No patching required then.

thanks Stephen, I did not know I could do that. That should solve my problem.

I dont know if I should open another thread for this or not, but in libselinux/src/load_policy.c
line 80:        libsepolh = dlopen("libsepol.so.1", RTLD_NOW);

Is hard coding .so.1 a security measure as well? Couldn't it be left to libsepol.so, with sym links to .so.1.2.3 ?


--
Vikram Ambrose | Linux Products Division | WindRiver Corporation


--
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.

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

  Powered by Linux