2008-08-19 19:30:36 +00:00
|
|
|
.TH "getexeccon" "3" "1 January 2004" "russell@coker.com.au" "SELinux API documentation"
|
|
|
|
.SH "NAME"
|
2012-11-13 20:15:34 +00:00
|
|
|
getexeccon, setexeccon \- get or set the SELinux security context used for executing a new process
|
2008-08-19 19:30:36 +00:00
|
|
|
|
|
|
|
rpm_execcon \- run a helper for rpm in an appropriate security context
|
2012-11-13 20:15:34 +00:00
|
|
|
.
|
2008-08-19 19:30:36 +00:00
|
|
|
.SH "SYNOPSIS"
|
|
|
|
.B #include <selinux/selinux.h>
|
|
|
|
.sp
|
2014-02-19 14:16:17 +00:00
|
|
|
.BI "int getexeccon(char **" context );
|
2012-11-13 20:15:34 +00:00
|
|
|
.sp
|
2014-02-19 14:16:17 +00:00
|
|
|
.BI "int getexeccon_raw(char **" context );
|
2012-11-10 03:32:07 +00:00
|
|
|
.sp
|
2014-02-19 14:16:17 +00:00
|
|
|
.BI "int setexeccon(char * "context );
|
2012-11-13 20:15:34 +00:00
|
|
|
.sp
|
2014-02-19 14:16:17 +00:00
|
|
|
.BI "int setexeccon_raw(char * "context );
|
2012-11-10 03:32:07 +00:00
|
|
|
.sp
|
2012-11-20 15:27:55 +00:00
|
|
|
.BI "int setexecfilecon(const char *" filename ", const char *" fallback_type );
|
|
|
|
.sp
|
2008-08-19 19:30:36 +00:00
|
|
|
.BI "int rpm_execcon(unsigned int " verified ", const char *" filename ", char *const " argv "[] , char *const " envp "[]);
|
2012-11-13 20:15:34 +00:00
|
|
|
.
|
2008-08-19 19:30:36 +00:00
|
|
|
.SH "DESCRIPTION"
|
2012-11-13 20:15:34 +00:00
|
|
|
.BR getexeccon ()
|
2008-08-19 19:30:36 +00:00
|
|
|
retrieves the context used for executing a new process.
|
2012-11-13 20:15:34 +00:00
|
|
|
This returned context should be freed with
|
|
|
|
.BR freecon (3)
|
|
|
|
if non-NULL.
|
|
|
|
.BR getexeccon ()
|
|
|
|
sets
|
|
|
|
.BI * context
|
|
|
|
to NULL if no exec context has been explicitly
|
2008-08-19 19:30:36 +00:00
|
|
|
set by the program (i.e. using the default policy behavior).
|
|
|
|
|
2012-11-13 20:15:34 +00:00
|
|
|
.BR setexeccon ()
|
|
|
|
sets the context used for the next
|
|
|
|
.BR execve (2)
|
|
|
|
call.
|
2008-08-19 19:30:36 +00:00
|
|
|
NULL can be passed to
|
2012-11-13 20:15:34 +00:00
|
|
|
.BR setexeccon ()
|
|
|
|
to reset to the default policy behavior.
|
|
|
|
The exec context is automatically reset after the next
|
|
|
|
.BR execve (2),
|
|
|
|
so a program doesn't need to explicitly sanitize it upon startup.
|
|
|
|
|
|
|
|
.BR setexeccon ()
|
|
|
|
can be applied prior to library
|
|
|
|
functions that internally perform an
|
|
|
|
.BR execve (2),
|
|
|
|
e.g.
|
|
|
|
.BR execl *(3),
|
|
|
|
.BR execv *(3),
|
|
|
|
.BR popen (3),
|
2008-08-19 19:30:36 +00:00
|
|
|
in order to set an exec context for that operation.
|
|
|
|
|
2012-11-10 03:32:07 +00:00
|
|
|
.BR getexeccon_raw ()
|
|
|
|
and
|
|
|
|
.BR setexeccon_raw ()
|
|
|
|
behave identically to their non-raw counterparts but do not perform context
|
|
|
|
translation.
|
|
|
|
|
2012-11-13 20:15:34 +00:00
|
|
|
.B Note:
|
|
|
|
Signal handlers that perform an
|
|
|
|
.BR execve (2)
|
|
|
|
must take care to
|
2008-08-19 19:30:36 +00:00
|
|
|
save, reset, and restore the exec context to avoid unexpected behavior.
|
|
|
|
|
2012-11-20 15:27:55 +00:00
|
|
|
.BR setexecfilecon ()
|
|
|
|
sets the context used for the next
|
|
|
|
.BR execve (2)
|
|
|
|
call, based on the policy for the
|
|
|
|
.IR filename ,
|
|
|
|
and falling back to a new context with a
|
|
|
|
.I fallback_type
|
|
|
|
in case there is no transition.
|
|
|
|
|
2012-11-13 20:15:34 +00:00
|
|
|
.BR rpm_execcon ()
|
2012-11-20 15:27:55 +00:00
|
|
|
is deprecated; please use
|
|
|
|
.BR setexecfilecon ()
|
|
|
|
in conjunction with
|
|
|
|
.BR execve (2)
|
|
|
|
in all new code. This function
|
2008-08-19 19:30:36 +00:00
|
|
|
runs a helper for rpm in an appropriate security context. The
|
|
|
|
verified parameter should contain the return code from the signature
|
|
|
|
verification (0 == ok, 1 == notfound, 2 == verifyfail, 3 ==
|
|
|
|
nottrusted, 4 == nokey), although this information is not yet used by
|
|
|
|
the function. The function determines the proper security context for
|
|
|
|
the helper based on policy, sets the exec context accordingly, and
|
|
|
|
then executes the specified filename with the provided argument and
|
|
|
|
environment arrays.
|
2012-11-13 20:15:34 +00:00
|
|
|
.
|
2008-08-19 19:30:36 +00:00
|
|
|
.SH "RETURN VALUE"
|
2012-11-13 20:15:34 +00:00
|
|
|
On error \-1 is returned.
|
|
|
|
|
|
|
|
On success
|
2012-11-20 15:27:55 +00:00
|
|
|
.BR getexeccon (),
|
2012-11-13 20:15:34 +00:00
|
|
|
.BR setexeccon ()
|
2012-11-20 15:27:55 +00:00
|
|
|
and
|
|
|
|
.BR setexecfilecon ()
|
|
|
|
return 0.
|
2012-11-13 20:15:34 +00:00
|
|
|
.BR rpm_execcon ()
|
|
|
|
only returns upon errors, as it calls
|
|
|
|
.BR execve (2).
|
|
|
|
.
|
2008-08-19 19:30:36 +00:00
|
|
|
.SH "SEE ALSO"
|
|
|
|
.BR selinux "(8), " freecon "(3), " getcon "(3)"
|