|
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 |
|