Chris PeBenito eb42163
## <summary>QEMU machine emulator and virtualizer</summary>
Chris PeBenito eb42163
Chris PeBenito 8a1c9c5
########################################
Chris PeBenito 8a1c9c5
## <summary>
Chris PeBenito 8a1c9c5
##	Creates types and rules for a basic
Chris PeBenito 8a1c9c5
##	qemu process domain.
Chris PeBenito 8a1c9c5
## </summary>
Chris PeBenito 8a1c9c5
## <param name="prefix">
Chris PeBenito 8a1c9c5
##	<summary>
Chris PeBenito 8a1c9c5
##	Prefix for the domain.
Chris PeBenito 8a1c9c5
##	</summary>
Chris PeBenito 8a1c9c5
## </param>
Chris PeBenito 8a1c9c5
#
Chris PeBenito 8a1c9c5
template(`qemu_domain_template',`
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	##############################
Chris PeBenito 8a1c9c5
	#
Chris PeBenito 8a1c9c5
	# Local Policy
Chris PeBenito 8a1c9c5
	#
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	type $1_t;
Chris PeBenito 8a1c9c5
	domain_type($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	type $1_tmp_t;
Chris PeBenito 8a1c9c5
	files_tmp_file($1_tmp_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	##############################
Chris PeBenito 8a1c9c5
	#
Chris PeBenito 8a1c9c5
	# Local Policy
Chris PeBenito 8a1c9c5
	#
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	allow $1_t self:capability { dac_read_search dac_override };
Chris PeBenito 8a1c9c5
	allow $1_t self:process { execstack execmem signal getsched };
Chris PeBenito 8a1c9c5
	allow $1_t self:fifo_file rw_file_perms;
Chris PeBenito 8a1c9c5
	allow $1_t self:shm create_shm_perms;
Chris PeBenito 8a1c9c5
	allow $1_t self:unix_stream_socket create_stream_socket_perms;
Chris PeBenito 8a1c9c5
	allow $1_t self:tcp_socket create_stream_socket_perms;
Chris PeBenito 8a1c9c5
	allow $1_t self:tun_socket create;
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	manage_dirs_pattern($1_t, $1_tmp_t, $1_tmp_t)
Chris PeBenito 8a1c9c5
	manage_files_pattern($1_t, $1_tmp_t, $1_tmp_t)
Chris PeBenito 8a1c9c5
	files_tmp_filetrans($1_t, $1_tmp_t, { file dir })
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	kernel_read_system_state($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	corenet_all_recvfrom_unlabeled($1_t)
Chris PeBenito 8a1c9c5
	corenet_all_recvfrom_netlabel($1_t)
Chris PeBenito 8a1c9c5
	corenet_tcp_sendrecv_generic_if($1_t)
Chris PeBenito 8a1c9c5
	corenet_tcp_sendrecv_generic_node($1_t)
Chris PeBenito 8a1c9c5
	corenet_tcp_sendrecv_all_ports($1_t)
Chris PeBenito 8a1c9c5
	corenet_tcp_bind_generic_node($1_t)
Chris PeBenito 8a1c9c5
	corenet_tcp_bind_vnc_port($1_t)
Chris PeBenito 8a1c9c5
	corenet_rw_tun_tap_dev($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
#	dev_rw_kvm($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	domain_use_interactive_fds($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	files_read_etc_files($1_t)
Chris PeBenito 8a1c9c5
	files_read_usr_files($1_t)
Chris PeBenito 8a1c9c5
	files_read_var_files($1_t)
Chris PeBenito 8a1c9c5
	files_search_all($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	fs_list_inotifyfs($1_t)
Chris PeBenito 8a1c9c5
	fs_rw_anon_inodefs_files($1_t)
Chris PeBenito 8a1c9c5
	fs_rw_tmpfs_files($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	storage_raw_write_removable_device($1_t)
Chris PeBenito 8a1c9c5
	storage_raw_read_removable_device($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	term_use_ptmx($1_t)
Chris PeBenito 8a1c9c5
	term_getattr_pty_fs($1_t)
Chris PeBenito 8a1c9c5
	term_use_generic_ptys($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	miscfiles_read_localization($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	sysnet_read_config($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	userdom_use_user_terminals($1_t)
Chris PeBenito 8a1c9c5
	userdom_attach_admin_tun_iface($1_t)
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	optional_policy(`
Chris PeBenito 8a1c9c5
		samba_domtrans_smbd($1_t)
Chris PeBenito 8a1c9c5
	')
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	optional_policy(`
Chris PeBenito 8a1c9c5
		virt_manage_images($1_t)
Chris PeBenito 8a1c9c5
		virt_read_config($1_t)
Chris PeBenito 8a1c9c5
		virt_read_lib_files($1_t)
Chris PeBenito 8a1c9c5
		virt_attach_tun_iface($1_t)
Chris PeBenito 8a1c9c5
	')
Chris PeBenito 8a1c9c5
Chris PeBenito 8a1c9c5
	optional_policy(`
Chris PeBenito 8a1c9c5
		xserver_stream_connect($1_t)
Chris PeBenito 8a1c9c5
		xserver_read_xdm_tmp_files($1_t)
Chris PeBenito 8a1c9c5
		xserver_read_xdm_pid($1_t)
Chris PeBenito 8a1c9c5
#		xserver_xdm_rw_shm($1_t)
Chris PeBenito 8a1c9c5
	')
Chris PeBenito 8a1c9c5
')
Chris PeBenito 8a1c9c5
Chris PeBenito 72295e9
#######################################
Chris PeBenito 72295e9
## <summary>
Chris PeBenito 72295e9
##	The per role template for the qemu module.
Chris PeBenito 72295e9
## </summary>
Chris PeBenito 72295e9
## <desc>
Chris PeBenito 72295e9
##	

Chris PeBenito 72295e9
##	This template creates a derived domains which are used
Chris PeBenito 72295e9
##	for qemu web browser.
Chris PeBenito 72295e9
##	

Chris PeBenito 72295e9
##	

Chris PeBenito 72295e9
##	This template is invoked automatically for each user, and
Chris PeBenito 72295e9
##	generally does not need to be invoked directly
Chris PeBenito 72295e9
##	by policy writers.
Chris PeBenito 72295e9
##	

Chris PeBenito 72295e9
## </desc>
Chris PeBenito 72295e9
## <param name="user_role">
Chris PeBenito 72295e9
##	<summary>
Chris PeBenito 72295e9
##	The role associated with the user domain.
Chris PeBenito 72295e9
##	</summary>
Chris PeBenito 72295e9
## </param>
Chris PeBenito 72295e9
## <param name="user_domain">
Chris PeBenito 72295e9
##	<summary>
Chris PeBenito 72295e9
##	The type of the user domain.
Chris PeBenito 72295e9
##	</summary>
Chris PeBenito 72295e9
## </param>
Chris PeBenito 72295e9
#
Chris PeBenito 72295e9
template(`qemu_role',`
Chris PeBenito 72295e9
	gen_require(`
Chris PeBenito 72295e9
		type qemu_t, qemu_exec_t;
Chris PeBenito 2c207df
		type qemu_config_t, qemu_config_exec_t;
Chris PeBenito 72295e9
	')
Chris PeBenito 72295e9
Chris PeBenito 72295e9
	role $1 types { qemu_t qemu_config_t };
Chris PeBenito 72295e9
Chris PeBenito 72295e9
	domtrans_pattern($2, qemu_exec_t, qemu_t)
Chris PeBenito 72295e9
 	domtrans_pattern($2, qemu_config_exec_t, qemu_config_t)
Chris PeBenito 2c207df
	allow qemu_t $2:process signull;
Chris PeBenito 72295e9
')
Chris PeBenito 72295e9
Chris PeBenito eb42163
########################################
Chris PeBenito eb42163
## <summary>
Chris PeBenito eb42163
##	Execute a domain transition to run qemu.
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## <param name="domain">
Chris PeBenito eb42163
## <summary>
Chris PeBenito eb42163
##	Domain allowed to transition.
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## </param>
Chris PeBenito eb42163
#
Chris PeBenito eb42163
interface(`qemu_domtrans',`
Chris PeBenito eb42163
	gen_require(`
Chris PeBenito eb42163
		type qemu_t, qemu_exec_t;
Chris PeBenito eb42163
	')
Chris PeBenito eb42163
Chris PeBenito eb42163
	domtrans_pattern($1, qemu_exec_t, qemu_t)
Chris PeBenito eb42163
')
Chris PeBenito eb42163
Chris PeBenito eb42163
########################################
Chris PeBenito eb42163
## <summary>
a75a591
##	Execute a qemu in the callers domain
a75a591
## </summary>
a75a591
## <param name="domain">
a75a591
## <summary>
a75a591
##	Domain allowed access.
a75a591
## </summary>
a75a591
## </param>
a75a591
#
a75a591
interface(`qemu_exec',`
a75a591
	gen_require(`
a75a591
		type qemu_exec_t;
a75a591
	')
a75a591
a75a591
	can_exec($1, qemu_exec_t)
a75a591
')
a75a591
a75a591
########################################
a75a591
## <summary>
Chris PeBenito eb42163
##	Execute qemu in the qemu domain.
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## <param name="domain">
Chris PeBenito eb42163
##	<summary>
Dominick Grift 03b8666
##	Domain allowed to transition.
Chris PeBenito eb42163
##	</summary>
Chris PeBenito eb42163
## </param>
Chris PeBenito eb42163
## <param name="role">
Chris PeBenito eb42163
##	<summary>
Chris PeBenito eb42163
##	The role to allow the qemu domain.
Chris PeBenito eb42163
##	</summary>
Chris PeBenito eb42163
## </param>
Chris PeBenito eb42163
#
Chris PeBenito eb42163
interface(`qemu_run',`
Chris PeBenito eb42163
	gen_require(`
Chris PeBenito eb42163
		type qemu_t;
Chris PeBenito eb42163
	')
Chris PeBenito eb42163
Chris PeBenito eb42163
	qemu_domtrans($1)
Chris PeBenito eb42163
	role $2 types qemu_t;
Chris PeBenito 72295e9
Chris PeBenito 72295e9
	optional_policy(`
Chris PeBenito 72295e9
		samba_run_smb(qemu_t, $2, $3)
Chris PeBenito 72295e9
	')
Chris PeBenito eb42163
')
Chris PeBenito eb42163
Chris PeBenito eb42163
########################################
Chris PeBenito eb42163
## <summary>
Chris PeBenito eb42163
##	Allow the domain to read state files in /proc.
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## <param name="domain">
Chris PeBenito eb42163
##	<summary>
Chris PeBenito eb42163
##	Domain to allow access.
Chris PeBenito eb42163
##	</summary>
Chris PeBenito eb42163
## </param>
Chris PeBenito eb42163
#
Chris PeBenito eb42163
interface(`qemu_read_state',`
Chris PeBenito eb42163
	gen_require(`
Chris PeBenito eb42163
		type qemu_t;
Chris PeBenito eb42163
	')
Chris PeBenito eb42163
Chris PeBenito eb42163
	read_files_pattern($1, qemu_t, qemu_t)
Chris PeBenito eb42163
')
Chris PeBenito eb42163
Chris PeBenito eb42163
########################################
Chris PeBenito eb42163
## <summary>
Chris PeBenito 72295e9
##	Set the schedule on qemu.
Chris PeBenito 72295e9
## </summary>
Chris PeBenito 72295e9
## <param name="domain">
Chris PeBenito 72295e9
##	<summary>
Chris PeBenito 72295e9
##	Domain allowed access.
Chris PeBenito 72295e9
##	</summary>
Chris PeBenito 72295e9
## </param>
Chris PeBenito 72295e9
#
Chris PeBenito 72295e9
interface(`qemu_setsched',`
Chris PeBenito 72295e9
	gen_require(`
Chris PeBenito 72295e9
		type qemu_t;
Chris PeBenito 72295e9
	')
Chris PeBenito 72295e9
Chris PeBenito 72295e9
	allow $1 qemu_t:process setsched;
Chris PeBenito 72295e9
')
Chris PeBenito 72295e9
Chris PeBenito 72295e9
########################################
Chris PeBenito 72295e9
## <summary>
Chris PeBenito eb42163
##	Send a signal to qemu.
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## <param name="domain">
Chris PeBenito eb42163
##	<summary>
Chris PeBenito eb42163
##	Domain allowed access.
Chris PeBenito eb42163
##	</summary>
Chris PeBenito eb42163
## </param>
Chris PeBenito eb42163
#
Chris PeBenito eb42163
interface(`qemu_signal',`
Chris PeBenito eb42163
	gen_require(`
Chris PeBenito eb42163
		type qemu_t;
Chris PeBenito eb42163
	')
Chris PeBenito eb42163
Chris PeBenito eb42163
	allow $1 qemu_t:process signal;
Chris PeBenito eb42163
')
Chris PeBenito eb42163
Chris PeBenito eb42163
########################################
Chris PeBenito eb42163
## <summary>
Chris PeBenito eb42163
##	Send a sigill to qemu
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## <param name="domain">
Chris PeBenito eb42163
##	<summary>
Chris PeBenito eb42163
##	Domain allowed access.
Chris PeBenito eb42163
##	</summary>
Chris PeBenito eb42163
## </param>
Chris PeBenito eb42163
#
Chris PeBenito eb42163
interface(`qemu_kill',`
Chris PeBenito eb42163
	gen_require(`
Chris PeBenito eb42163
		type qemu_t;
Chris PeBenito eb42163
	')
Chris PeBenito eb42163
Chris PeBenito eb42163
	allow $1 qemu_t:process sigkill;
Chris PeBenito eb42163
')
Chris PeBenito eb42163
Chris PeBenito eb42163
########################################
Chris PeBenito eb42163
## <summary>
Chris PeBenito eb42163
##	Execute a domain transition to run qemu unconfined.
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## <param name="domain">
Chris PeBenito eb42163
## <summary>
Chris PeBenito eb42163
##	Domain allowed to transition.
Chris PeBenito eb42163
## </summary>
Chris PeBenito eb42163
## </param>
Chris PeBenito eb42163
#
Chris PeBenito eb42163
interface(`qemu_domtrans_unconfined',`
Chris PeBenito eb42163
	gen_require(`
Chris PeBenito a777957
		type unconfined_qemu_t, qemu_exec_t;
Chris PeBenito eb42163
	')
Chris PeBenito eb42163
Chris PeBenito a777957
	domtrans_pattern($1, qemu_exec_t, unconfined_qemu_t)
Chris PeBenito eb42163
')
Chris PeBenito eb42163
Chris PeBenito eb42163
########################################
Chris PeBenito eb42163
## <summary>
3eaa993
##	Execute qemu_exec_t 
3eaa993
##	in the specified domain but do not
3eaa993
##	do it automatically. This is an explicit
3eaa993
##	transition, requiring the caller to use setexeccon().
3eaa993
## </summary>
3eaa993
## <desc>
3eaa993
##	

3eaa993
##	Execute qemu_exec_t 
3eaa993
##	in the specified domain.  This allows
3eaa993
##	the specified domain to qemu programs
3eaa993
##	on these filesystems in the specified
3eaa993
##	domain.
3eaa993
##	

3eaa993
## </desc>
3eaa993
## <param name="domain">
3eaa993
##	<summary>
3eaa993
##	Domain allowed access.
3eaa993
##	</summary>
3eaa993
## </param>
3eaa993
## <param name="target_domain">
3eaa993
##	<summary>
3eaa993
##	The type of the new process.
3eaa993
##	</summary>
3eaa993
## </param>
3eaa993
#
3eaa993
interface(`qemu_spec_domtrans',`
3eaa993
	gen_require(`
3eaa993
		type qemu_exec_t;
3eaa993
	')
3eaa993
  
3eaa993
	read_lnk_files_pattern($1, qemu_exec_t, qemu_exec_t)
3eaa993
	domain_transition_pattern($1, qemu_exec_t, $2)
3eaa993
  	domain_entry_file($2,qemu_exec_t)
3eaa993
	can_exec($1,qemu_exec_t)
3eaa993
3eaa993
	allow $2 $1:fd use;
3eaa993
	allow $2 $1:fifo_file rw_fifo_file_perms;
3eaa993
	allow $2 $1:process sigchld;
3eaa993
')
3eaa993
3eaa993
########################################
3eaa993
## <summary>
3eaa993
##	Execute qemu unconfined programs in the role.
3eaa993
## </summary>
3eaa993
## <param name="role">
3eaa993
##	<summary>
ddd1cca
##	The role to allow the qemu unconfined domain.
3eaa993
##	</summary>
3eaa993
## </param>
3eaa993
#
3eaa993
interface(`qemu_unconfined_role',`
3eaa993
	gen_require(`
3eaa993
		type unconfined_qemu_t;
3eaa993
		type qemu_t;
3eaa993
	')
3eaa993
	role $1 types unconfined_qemu_t;
3eaa993
	role $1 types qemu_t;
3eaa993
')
3eaa993
3eaa993
########################################
3eaa993
## <summary>
Chris PeBenito 72295e9
##	Manage qemu temporary dirs.
Chris PeBenito 72295e9
## </summary>
Chris PeBenito 72295e9
## <param name="domain">
Chris PeBenito 72295e9
##	<summary>
Chris PeBenito 72295e9
##	Domain allowed access.
Chris PeBenito 72295e9
##	</summary>
Chris PeBenito 72295e9
## </param>
Chris PeBenito 72295e9
#
Chris PeBenito 72295e9
interface(`qemu_manage_tmp_dirs',`
Chris PeBenito 72295e9
	gen_require(`
Chris PeBenito 72295e9
		type qemu_tmp_t;
Chris PeBenito 72295e9
	')
Chris PeBenito 72295e9
Chris PeBenito 72295e9
	manage_dirs_pattern($1, qemu_tmp_t, qemu_tmp_t)
Chris PeBenito 72295e9
')
Chris PeBenito 72295e9
Chris PeBenito 72295e9
########################################
Chris PeBenito 72295e9
## <summary>
Chris PeBenito 72295e9
##	Manage qemu temporary files.
Chris PeBenito 72295e9
## </summary>
Chris PeBenito 72295e9
## <param name="domain">
Chris PeBenito 72295e9
##	<summary>
Chris PeBenito 72295e9
##	Domain allowed access.
Chris PeBenito 72295e9
##	</summary>
Chris PeBenito 72295e9
## </param>
Chris PeBenito 72295e9
#
Chris PeBenito 72295e9
interface(`qemu_manage_tmp_files',`
Chris PeBenito 72295e9
	gen_require(`
Chris PeBenito 72295e9
		type qemu_tmp_t;
Chris PeBenito 72295e9
	')
Chris PeBenito 72295e9
Chris PeBenito 72295e9
	manage_files_pattern($1, qemu_tmp_t, qemu_tmp_t)
Chris PeBenito 72295e9
')
3eaa993
3eaa993
########################################
3eaa993
## <summary>
3eaa993
##     Make qemu_exec_t an entrypoint for
3eaa993
##     the specified domain.
3eaa993
## </summary>
3eaa993
## <param name="domain">
3eaa993
##     <summary>
3eaa993
##     The domain for which qemu_exec_t is an entrypoint.
3eaa993
##     </summary>
3eaa993
## </param>
3eaa993
#
3eaa993
interface(`qemu_entry_type',`
3eaa993
	gen_require(`
3eaa993
		type qemu_exec_t;
3eaa993
	')
3eaa993
3eaa993
	domain_entry_file($1, qemu_exec_t)
3eaa993
')
3eaa993
3eaa993