Chris PeBenito 9401ae1
## <summary>SELinux utility to run a shell with a new role</summary>
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
#######################################
Chris PeBenito 9401ae1
## <summary>
Chris PeBenito 9401ae1
##	The role template for the userhelper module.
Chris PeBenito 9401ae1
## </summary>
Chris PeBenito 9401ae1
## <param name="userrole_prefix">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	The prefix of the user role (e.g., user
Chris PeBenito 9401ae1
##	is the prefix for user_r).
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
## <param name="user_role">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	The user role.
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
## <param name="user_domain">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	The user domain associated with the role.
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
#
Chris PeBenito 9401ae1
template(`userhelper_role_template',`
Chris PeBenito 9401ae1
	gen_require(`
Chris PeBenito 9401ae1
		attribute userhelper_type;
Chris PeBenito 9401ae1
		type userhelper_exec_t, userhelper_conf_t;
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	########################################
Chris PeBenito 9401ae1
	#
Chris PeBenito 9401ae1
	# Declarations
Chris PeBenito 9401ae1
	#
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	type $1_userhelper_t, userhelper_type;
Chris PeBenito 66b26ac
	userdom_user_application_domain($1_userhelper_t, userhelper_exec_t)
Chris PeBenito 9401ae1
	domain_role_change_exemption($1_userhelper_t)
Chris PeBenito 9401ae1
	domain_obj_id_change_exemption($1_userhelper_t)
Chris PeBenito 9401ae1
	domain_interactive_fd($1_userhelper_t)
Chris PeBenito 9401ae1
	domain_subj_id_change_exemption($1_userhelper_t)
Chris PeBenito 9401ae1
	role $2 types $1_userhelper_t;
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	########################################
Chris PeBenito 9401ae1
	#
Chris PeBenito 9401ae1
	# Local policy
Chris PeBenito 9401ae1
	#
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:capability { setuid setgid net_bind_service dac_override chown sys_tty_config };
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:process ~{ ptrace setcurrent setexec setfscreate setrlimit execmem execstack execheap };
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:process setexec;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:fd use;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:fifo_file rw_fifo_file_perms;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:shm create_shm_perms;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:sem create_sem_perms;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:msgq create_msgq_perms;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:msg { send receive };
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:unix_dgram_socket create_socket_perms;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:unix_stream_socket create_stream_socket_perms;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:unix_dgram_socket sendto;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:unix_stream_socket connectto;
Chris PeBenito 9401ae1
	allow $1_userhelper_t self:sock_file read_sock_file_perms;
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	#Transition to the derived domain.
Chris PeBenito 9401ae1
	domtrans_pattern($3, userhelper_exec_t, $1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	allow $1_userhelper_t userhelper_conf_t:dir rw_dir_perms;
Chris PeBenito 9401ae1
	rw_files_pattern($1_userhelper_t, userhelper_conf_t, userhelper_conf_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	can_exec($1_userhelper_t, userhelper_exec_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	dontaudit $3 $1_userhelper_t:process signal;
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	kernel_read_all_sysctls($1_userhelper_t)
Chris PeBenito 9401ae1
	kernel_getattr_debugfs($1_userhelper_t)
Chris PeBenito 9401ae1
	kernel_read_system_state($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	# Execute shells
Chris PeBenito 9401ae1
	corecmd_exec_shell($1_userhelper_t)
Chris PeBenito 9401ae1
	# By default, revert to the calling domain when a program is executed
Chris PeBenito 9401ae1
	corecmd_bin_domtrans($1_userhelper_t, $3)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	# Inherit descriptors from the current session.
Chris PeBenito 9401ae1
	domain_use_interactive_fds($1_userhelper_t)
Chris PeBenito 9401ae1
	# for when the user types "exec userhelper" at the command line
Chris PeBenito 9401ae1
	domain_sigchld_interactive_fds($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	dev_read_urand($1_userhelper_t)
Chris PeBenito 9401ae1
	# Read /dev directories and any symbolic links.
Chris PeBenito 9401ae1
	dev_list_all_dev_nodes($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	files_list_var_lib($1_userhelper_t)
Chris PeBenito 9401ae1
	# Read the /etc/security/default_type file
Chris PeBenito 9401ae1
	files_read_etc_files($1_userhelper_t)
Chris PeBenito 9401ae1
	# Read /var.
Chris PeBenito 9401ae1
	files_read_var_files($1_userhelper_t)
Chris PeBenito 9401ae1
	files_read_var_symlinks($1_userhelper_t)
Chris PeBenito 9401ae1
	# for some PAM modules and for cwd
Chris PeBenito 9401ae1
	files_search_home($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	fs_search_auto_mountpoints($1_userhelper_t)
Chris PeBenito 9401ae1
	fs_read_nfs_files($1_userhelper_t)
Chris PeBenito 9401ae1
	fs_read_nfs_symlinks($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	# Allow $1_userhelper to obtain contexts to relabel TTYs
Chris PeBenito 9401ae1
	selinux_get_fs_mount($1_userhelper_t)
Chris PeBenito 9401ae1
	selinux_validate_context($1_userhelper_t)
Chris PeBenito 9401ae1
	selinux_compute_access_vector($1_userhelper_t)
Chris PeBenito 9401ae1
	selinux_compute_create_context($1_userhelper_t)
Chris PeBenito 9401ae1
	selinux_compute_relabel_context($1_userhelper_t)
Chris PeBenito 9401ae1
	selinux_compute_user_contexts($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	# Read the devpts root directory.
Chris PeBenito 9401ae1
	term_list_ptys($1_userhelper_t)
Chris PeBenito 9401ae1
	# Relabel terminals.
Chris PeBenito 9401ae1
	term_relabel_all_ttys($1_userhelper_t)
Chris PeBenito 9401ae1
	term_relabel_all_ptys($1_userhelper_t)
Chris PeBenito 9401ae1
	# Access terminals.
Chris PeBenito 9401ae1
	term_use_all_ttys($1_userhelper_t)
Chris PeBenito 9401ae1
	term_use_all_ptys($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	auth_domtrans_chk_passwd($1_userhelper_t)
Chris PeBenito 9401ae1
	auth_manage_pam_pid($1_userhelper_t)
Chris PeBenito 9401ae1
	auth_manage_var_auth($1_userhelper_t)
Chris PeBenito 9401ae1
	auth_search_pam_console_data($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	# Inherit descriptors from the current session.
Chris PeBenito 9401ae1
	init_use_fds($1_userhelper_t)
Chris PeBenito 9401ae1
	# Write to utmp.
Chris PeBenito 9401ae1
	init_manage_utmp($1_userhelper_t)
Chris PeBenito 9401ae1
	init_pid_filetrans_utmp($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	miscfiles_read_localization($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	seutil_read_config($1_userhelper_t)
Chris PeBenito 9401ae1
	seutil_read_default_contexts($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	# Allow $1_userhelper_t to transition to user domains.
Chris PeBenito 9401ae1
	userdom_bin_spec_domtrans_unpriv_users($1_userhelper_t)
Chris PeBenito 9401ae1
	userdom_entry_spec_domtrans_unpriv_users($1_userhelper_t)
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	ifdef(`distro_redhat',`
Chris PeBenito 9401ae1
		optional_policy(`
Chris PeBenito 9401ae1
			# Allow transitioning to rpm_t, for up2date
Chris PeBenito 9401ae1
			rpm_domtrans($1_userhelper_t)
Chris PeBenito 9401ae1
		')
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	optional_policy(`
Chris PeBenito 9401ae1
		logging_send_syslog_msg($1_userhelper_t)
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	optional_policy(`
Chris PeBenito 9401ae1
		nis_use_ypbind($1_userhelper_t)
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	optional_policy(`
Chris PeBenito 9401ae1
		nscd_socket_use($1_userhelper_t)
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	optional_policy(`
Chris PeBenito 9401ae1
		tunable_policy(`! secure_mode',`
Chris PeBenito 9401ae1
			#if we are not in secure mode then we can transition to sysadm_t
Chris PeBenito 9401ae1
			sysadm_bin_spec_domtrans($1_userhelper_t)
Chris PeBenito 9401ae1
			sysadm_entry_spec_domtrans($1_userhelper_t)
Chris PeBenito 9401ae1
		')
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
########################################
Chris PeBenito 9401ae1
## <summary>
Chris PeBenito 9401ae1
##	Search the userhelper configuration directory.
Chris PeBenito 9401ae1
## </summary>
Chris PeBenito 9401ae1
## <param name="domain">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	Domain allowed access.
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
#
Chris PeBenito 9401ae1
interface(`userhelper_search_config',`
Chris PeBenito 9401ae1
	gen_require(`
Chris PeBenito 9401ae1
		type userhelper_conf_t;
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	allow $1 userhelper_conf_t:dir search_dir_perms;
Chris PeBenito 9401ae1
')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
########################################
Chris PeBenito 9401ae1
## <summary>
Chris PeBenito 9401ae1
##	Do not audit attempts to search
Chris PeBenito 9401ae1
##	the userhelper configuration directory.
Chris PeBenito 9401ae1
## </summary>
Chris PeBenito 9401ae1
## <param name="domain">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	Domain to not audit.
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
#
Chris PeBenito 9401ae1
interface(`userhelper_dontaudit_search_config',`
Chris PeBenito 9401ae1
	gen_require(`
Chris PeBenito 9401ae1
		type userhelper_conf_t;
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	dontaudit $1 userhelper_conf_t:dir search_dir_perms;
Chris PeBenito 9401ae1
')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
########################################
Chris PeBenito 9401ae1
## <summary>
Chris PeBenito 9401ae1
##	Allow domain to use userhelper file descriptor.
Chris PeBenito 9401ae1
## </summary>
Chris PeBenito 9401ae1
## <param name="domain">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	Domain allowed access.
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
#
Chris PeBenito 9401ae1
interface(`userhelper_use_fd',`
Chris PeBenito 9401ae1
	gen_require(`
Chris PeBenito 9401ae1
		attribute userhelper_type;
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	allow $1 userhelper_type:fd use;
Chris PeBenito 9401ae1
')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
########################################
Chris PeBenito 9401ae1
## <summary>
Chris PeBenito 9401ae1
##	Allow domain to send sigchld to userhelper.
Chris PeBenito 9401ae1
## </summary>
Chris PeBenito 9401ae1
## <param name="domain">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	Domain allowed access.
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
#
Chris PeBenito 9401ae1
interface(`userhelper_sigchld',`
Chris PeBenito 9401ae1
	gen_require(`
Chris PeBenito 9401ae1
		attribute userhelper_type;
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	allow $1 userhelper_type:process sigchld;
Chris PeBenito 9401ae1
')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
########################################
Chris PeBenito 9401ae1
## <summary>
Chris PeBenito 9401ae1
##	Execute the userhelper program in the caller domain.
Chris PeBenito 9401ae1
## </summary>
Chris PeBenito 9401ae1
## <param name="domain">
Chris PeBenito 9401ae1
##	<summary>
Chris PeBenito 9401ae1
##	Domain allowed access.
Chris PeBenito 9401ae1
##	</summary>
Chris PeBenito 9401ae1
## </param>
Chris PeBenito 9401ae1
#
Chris PeBenito 9401ae1
interface(`userhelper_exec',`
Chris PeBenito 9401ae1
	gen_require(`
Chris PeBenito 9401ae1
		type userhelper_exec_t;
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
Chris PeBenito 9401ae1
	can_exec($1, userhelper_exec_t)
Chris PeBenito 9401ae1
')