2012-08-10 14:31:14 +01:00
/*
* Copyright ( C ) 2011 - 2012 Red Hat , Inc .
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
2012-09-20 16:30:55 -06:00
* License along with this library . If not , see
2012-08-10 14:31:14 +01:00
* < http : //www.gnu.org/licenses/>.
*
*/
# include <config.h>
# include <selinux/selinux.h>
# include <stdlib.h>
# include <string.h>
# include <unistd.h>
# include <errno.h>
2013-01-14 13:45:55 -05:00
# if WITH_ATTR
# include <attr / xattr.h>
# endif
2012-09-19 14:00:34 +01:00
2013-05-03 14:52:21 +02:00
# include "virstring.h"
2012-09-19 14:00:34 +01:00
2012-08-10 14:31:14 +01:00
/*
* The kernel policy will not allow us to arbitrarily change
* test process context . This helper is used as an LD_PRELOAD
* so that the libvirt code / thinks / it is changing / reading
* the process context , where as in fact we ' re faking it all
*/
2012-10-05 16:41:22 +02:00
int getcon_raw ( security_context_t * context )
2012-08-10 14:31:14 +01:00
{
if ( getenv ( " FAKE_CONTEXT " ) = = NULL ) {
* context = NULL ;
errno = EINVAL ;
return - 1 ;
}
2013-05-03 14:52:21 +02:00
return VIR_STRDUP_QUIET ( * context , getenv ( " FAKE_CONTEXT " ) ) ;
2012-08-10 14:31:14 +01:00
}
2013-01-14 18:33:44 +00:00
int getcon ( security_context_t * context )
{
return getcon_raw ( context ) ;
}
2012-10-05 16:41:22 +02:00
int getpidcon_raw ( pid_t pid , security_context_t * context )
2012-08-10 14:31:14 +01:00
{
if ( pid ! = getpid ( ) ) {
* context = NULL ;
errno = ESRCH ;
return - 1 ;
}
if ( getenv ( " FAKE_CONTEXT " ) = = NULL ) {
* context = NULL ;
errno = EINVAL ;
return - 1 ;
}
2013-05-03 14:52:21 +02:00
return VIR_STRDUP_QUIET ( * context , getenv ( " FAKE_CONTEXT " ) ) ;
2012-08-10 14:31:14 +01:00
}
2013-01-14 18:33:44 +00:00
int getpidcon ( pid_t pid , security_context_t * context )
{
return getpidcon_raw ( pid , context ) ;
}
2012-10-05 16:41:22 +02:00
int setcon_raw ( security_context_t context )
2012-08-10 14:31:14 +01:00
{
return setenv ( " FAKE_CONTEXT " , context , 1 ) ;
}
2012-09-19 14:00:34 +01:00
2013-01-14 18:33:44 +00:00
int setcon ( security_context_t context )
{
return setcon_raw ( context ) ;
}
2012-09-19 14:00:34 +01:00
# if WITH_ATTR
2013-01-14 18:33:44 +00:00
int setfilecon_raw ( const char * path , security_context_t con )
2012-09-19 14:00:34 +01:00
{
const char * constr = con ;
return setxattr ( path , " user.libvirt.selinux " ,
constr , strlen ( constr ) , 0 ) ;
}
2013-01-14 18:33:44 +00:00
int setfilecon ( const char * path , security_context_t con )
{
return setfilecon_raw ( path , con ) ;
}
2012-09-19 14:00:34 +01:00
2013-01-14 18:33:44 +00:00
int getfilecon_raw ( const char * path , security_context_t * con )
2012-09-19 14:00:34 +01:00
{
char * constr = NULL ;
ssize_t len = getxattr ( path , " user.libvirt.selinux " ,
NULL , 0 ) ;
if ( len < 0 )
return - 1 ;
if ( ! ( constr = malloc ( len + 1 ) ) )
return - 1 ;
memset ( constr , 0 , len ) ;
if ( getxattr ( path , " user.libvirt.selinux " , constr , len ) < 0 ) {
free ( constr ) ;
return - 1 ;
}
* con = constr ;
constr [ len ] = ' \0 ' ;
return 0 ;
}
2013-01-14 18:33:44 +00:00
int getfilecon ( const char * path , security_context_t * con )
{
return getfilecon_raw ( path , con ) ;
}
2012-09-19 14:00:34 +01:00
# endif