1ec3d1a
## <summary>Pulseaudio network sound server.</summary>
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Role access for pulseaudio
1ec3d1a
## </summary>
1ec3d1a
## <param name="role">
1ec3d1a
##	<summary>
b43f464
##	Role allowed access
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
b43f464
##	User domain for the role
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_role',`
1ec3d1a
	gen_require(`
b43f464
		type pulseaudio_t, pulseaudio_exec_t;
b43f464
		class dbus { acquire_svc send_msg };
1ec3d1a
	')
1ec3d1a
b43f464
	role $1 types pulseaudio_t;
1ec3d1a
b43f464
	# Transition from the user domain to the derived domain.
b43f464
	domtrans_pattern($2, pulseaudio_exec_t, pulseaudio_t)
1ec3d1a
b43f464
	ps_process_pattern($2, pulseaudio_t)
1ec3d1a
b43f464
	allow pulseaudio_t $2:process { signal signull };
b43f464
	allow $2 pulseaudio_t:process { signal signull sigkill };
b43f464
	ps_process_pattern(pulseaudio_t, $2)
1ec3d1a
b43f464
	allow pulseaudio_t $2:unix_stream_socket connectto;
b43f464
	allow $2 pulseaudio_t:unix_stream_socket connectto;
Dominick Grift 9296c89
1ec3d1a
	userdom_manage_tmp_role($1, pulseaudio_t)
1ec3d1a
	userdom_manage_tmpfs_role($1, pulseaudio_t)
1ec3d1a
1ec3d1a
	allow $2 pulseaudio_t:dbus send_msg;
1ec3d1a
	allow pulseaudio_t $2:dbus { acquire_svc send_msg };
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute a domain transition to run pulseaudio.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
## <summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
## </summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_domtrans',`
1ec3d1a
	gen_require(`
1f86dac
		attribute pulseaudio_client;
1ec3d1a
		type pulseaudio_t, pulseaudio_exec_t;
1ec3d1a
	')
1ec3d1a
1f86dac
	typeattribute $1 pulseaudio_client;
1f86dac
1f86dac
	corecmd_search_bin($1)
1ec3d1a
	domtrans_pattern($1, pulseaudio_exec_t, pulseaudio_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Execute pulseaudio in the pulseaudio domain, and
b43f464
##	allow the specified role the pulseaudio domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="role">
1ec3d1a
##	<summary>
1ec3d1a
##	Role allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_run',`
1ec3d1a
	gen_require(`
b43f464
		type pulseaudio_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	pulseaudio_domtrans($1)
b43f464
	role $2 types pulseaudio_t;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Execute a pulseaudio in the current domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
## <summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
## </summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_exec',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	can_exec($1, pulseaudio_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Do not audit to execute a pulseaudio.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
## <summary>
1ec3d1a
##	Domain to not audit.
1ec3d1a
## </summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_dontaudit_exec',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	dontaudit $1 pulseaudio_exec_t:file exec_file_perms;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Send signull signal to pulseaudio
1ec3d1a
##	processes.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_signull',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 pulseaudio_t:process signull;
1ec3d1a
')
1ec3d1a
1ec3d1a
#####################################
1ec3d1a
## <summary>
b43f464
##	Connect to pulseaudio over a unix domain
b43f464
##	stream socket.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_stream_connect',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_t, pulseaudio_var_run_t;
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_pids($1)
1ec3d1a
	allow $1 pulseaudio_t:process signull;
1ec3d1a
	allow pulseaudio_t $1:process signull;
1ec3d1a
	stream_connect_pattern($1, pulseaudio_var_run_t, pulseaudio_var_run_t, pulseaudio_t)
1ec3d1a
	stream_connect_pattern($1, pulseaudio_home_t, pulseaudio_home_t, pulseaudio_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Send and receive messages from
1ec3d1a
##	pulseaudio over dbus.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_dbus_chat',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_t;
1ec3d1a
		class dbus send_msg;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 pulseaudio_t:dbus send_msg;
1ec3d1a
	allow pulseaudio_t $1:dbus send_msg;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Set the attributes of the pulseaudio homedir.
1ec3d1a
## </summary>
b43f464
## <param name="user_domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_setattr_home_dir',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
b43f464
	allow $1 pulseaudio_home_t:dir setattr;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Read pulseaudio homedir files.
1ec3d1a
## </summary>
b43f464
## <param name="user_domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_read_home_files',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	userdom_search_user_home_dirs($1)
b43f464
	read_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t)
b43f464
	read_lnk_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Read and write Pulse Audio files.
1ec3d1a
## </summary>
b43f464
## <param name="user_domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_rw_home_files',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	rw_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t)
1ec3d1a
	read_lnk_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t)
b43f464
	userdom_search_user_home_dirs($1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Create, read, write, and delete pulseaudio
b43f464
##	home directory files.
1ec3d1a
## </summary>
b43f464
## <param name="user_domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_manage_home_files',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	userdom_search_user_home_dirs($1)
1ec3d1a
	manage_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t)
1ec3d1a
	read_lnk_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t)
1ec3d1a
	pulseaudio_filetrans_home_content($1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Create, read, write, and delete pulseaudio
1ec3d1a
##	home directory symlinks.
1ec3d1a
## </summary>
1ec3d1a
## <param name="user_domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_manage_home_symlinks',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	userdom_search_user_home_dirs($1)
1ec3d1a
	manage_lnk_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Create pulseaudio content in the user home directory
1ec3d1a
##	with an correct label.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_filetrans_home_content',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	userdom_user_home_dir_filetrans($1, pulseaudio_home_t, dir, ".pulse")
1ec3d1a
	userdom_user_home_dir_filetrans($1, pulseaudio_home_t, file, ".pulse-cookie")
1ec3d1a
	userdom_user_home_dir_filetrans($1, pulseaudio_home_t, file, ".esd_auth")
bed0f54
	optional_policy(`
bed0f54
		gnome_config_filetrans($1, pulseaudio_home_t, dir, "pulse")
bed0f54
	')
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Create pulseaudio content in the admin home directory
1ec3d1a
##	with an correct label.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`pulseaudio_filetrans_admin_home_content',`
1ec3d1a
	gen_require(`
1ec3d1a
		type pulseaudio_home_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	userdom_admin_home_dir_filetrans($1, pulseaudio_home_t, dir, ".pulse")
1ec3d1a
	userdom_admin_home_dir_filetrans($1, pulseaudio_home_t, file, ".pulse-cookie")
1ec3d1a
	userdom_admin_home_dir_filetrans($1, pulseaudio_home_t, file, ".esd_auth")
1ec3d1a
')
7a67ccf
1f86dac
#######################################
1f86dac
## <summary>
1f86dac
##  Make the specified tmpfs file type
1f86dac
##  pulseaudio tmpfs content.
1f86dac
## </summary>
1f86dac
## <param name="file_type">
1f86dac
##  <summary>
1f86dac
##  File type to make pulseaudio tmpfs content.
1f86dac
##  </summary>
1f86dac
## </param>
1f86dac
#
1f86dac
interface(`pulseaudio_tmpfs_content',`
1f86dac
    gen_require(`
1f86dac
        attribute pulseaudio_tmpfsfile;
1f86dac
    ')
1f86dac
1f86dac
    typeattribute $1 pulseaudio_tmpfsfile;
1f86dac
')
1f86dac
7a67ccf
########################################
7a67ccf
## <summary>
7a67ccf
##	Allow the domain to read pulseaudio state files in /proc.
7a67ccf
## </summary>
7a67ccf
## <param name="domain">
7a67ccf
##	<summary>
7a67ccf
##	Domain allowed access.
7a67ccf
##	</summary>
7a67ccf
## </param>
7a67ccf
#
7a67ccf
interface(`pulseaudio_read_state',`
7a67ccf
	gen_require(`
7a67ccf
		type pulseaudio_t;
7a67ccf
	')
7a67ccf
7a67ccf
	kernel_search_proc($1)
7a67ccf
	ps_process_pattern($1, pulseaudio_t)
7a67ccf
')