57 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * libbb/selinux_common.c
 | 
						|
 *   -- common SELinux utility functions
 | 
						|
 *
 | 
						|
 * Copyright 2007 KaiGai Kohei <kaigai@kaigai.gr.jp>
 | 
						|
 *
 | 
						|
 * Licensed under GPLv2, see file LICENSE in this tarball for details.
 | 
						|
 */
 | 
						|
#include "libbb.h"
 | 
						|
#include <selinux/context.h>
 | 
						|
 | 
						|
context_t FAST_FUNC set_security_context_component(security_context_t cur_context,
 | 
						|
					 char *user, char *role, char *type, char *range)
 | 
						|
{
 | 
						|
	context_t con = context_new(cur_context);
 | 
						|
	if (!con)
 | 
						|
		return NULL;
 | 
						|
 | 
						|
	if (user && context_user_set(con, user))
 | 
						|
		goto error;
 | 
						|
	if (type && context_type_set(con, type))
 | 
						|
		goto error;
 | 
						|
	if (range && context_range_set(con, range))
 | 
						|
		goto error;
 | 
						|
	if (role && context_role_set(con, role))
 | 
						|
		goto error;
 | 
						|
	return con;
 | 
						|
 | 
						|
error:
 | 
						|
	context_free(con);
 | 
						|
	return NULL;
 | 
						|
}
 | 
						|
 | 
						|
void FAST_FUNC setfscreatecon_or_die(security_context_t scontext)
 | 
						|
{
 | 
						|
	if (setfscreatecon(scontext) < 0) {
 | 
						|
		/* Can be NULL. All known printf implementations
 | 
						|
		 * display "(null)", "<null>" etc */
 | 
						|
		bb_perror_msg_and_die("can't set default "
 | 
						|
				"file creation context to %s", scontext);
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
void FAST_FUNC selinux_preserve_fcontext(int fdesc)
 | 
						|
{
 | 
						|
	security_context_t context;
 | 
						|
 | 
						|
	if (fgetfilecon(fdesc, &context) < 0) {
 | 
						|
		if (errno == ENODATA || errno == ENOTSUP)
 | 
						|
			return;
 | 
						|
		bb_perror_msg_and_die("fgetfilecon failed");
 | 
						|
	}
 | 
						|
	setfscreatecon_or_die(context);
 | 
						|
	freecon(context);
 | 
						|
}
 | 
						|
 |