1ec3d1a
## <summary>Policy framework for controlling privileges for system-wide services.</summary>
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Send and receive messages from
1ec3d1a
##	policykit over dbus.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_dbus_chat',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_t;
1ec3d1a
		class dbus send_msg;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	ps_process_pattern(policykit_t, $1)
1ec3d1a
1ec3d1a
	allow $1 policykit_t:dbus send_msg;
1ec3d1a
	allow policykit_t $1:dbus send_msg;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Send and receive messages from
1ec3d1a
##	policykit over dbus.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_dbus_chat_auth',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_auth_t;
1ec3d1a
		class dbus send_msg;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	ps_process_pattern(policykit_auth_t, $1)
1ec3d1a
1ec3d1a
	allow $1 policykit_auth_t:dbus send_msg;
1ec3d1a
	allow policykit_auth_t $1:dbus send_msg;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute a domain transition to run polkit_auth.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_domtrans_auth',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_auth_t, policykit_auth_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, policykit_auth_exec_t, policykit_auth_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute a policy_auth in the policy_auth domain, and
1ec3d1a
##	allow the specified role the policy_auth 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
## <rolecap/>
1ec3d1a
#
1ec3d1a
interface(`policykit_run_auth',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_auth_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	policykit_domtrans_auth($1)
1ec3d1a
	role $2 types policykit_auth_t;
1ec3d1a
1ec3d1a
	allow $1 policykit_auth_t:process signal;
1ec3d1a
	ps_process_pattern(policykit_auth_t, $1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute a domain transition to run polkit_grant.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_domtrans_grant',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_grant_t, policykit_grant_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, policykit_grant_exec_t, policykit_grant_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute a policy_grant in the policy_grant domain, and
1ec3d1a
##	allow the specified role the policy_grant 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
## <rolecap/>
1ec3d1a
#
1ec3d1a
interface(`policykit_run_grant',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_grant_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	policykit_domtrans_grant($1)
1ec3d1a
	role $2 types policykit_grant_t;
1ec3d1a
1ec3d1a
	allow $1 policykit_grant_t:process signal;
1ec3d1a
1ec3d1a
	ps_process_pattern(policykit_grant_t, $1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	read policykit reload files
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_read_reload',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_reload_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_var_lib($1)
1ec3d1a
	read_files_pattern($1, policykit_reload_t, policykit_reload_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	rw policykit reload files
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_rw_reload',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_reload_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_var_lib($1)
1ec3d1a
	rw_files_pattern($1, policykit_reload_t, policykit_reload_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute a domain transition to run polkit_resolve.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_domtrans_resolve',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_resolve_t, policykit_resolve_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, policykit_resolve_exec_t, policykit_resolve_t)
1ec3d1a
1ec3d1a
	ps_process_pattern(policykit_resolve_t, $1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Search policykit lib directories.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_search_lib',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_var_lib_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 policykit_var_lib_t:dir search_dir_perms;
1ec3d1a
	files_search_var_lib($1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	read policykit lib files
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_read_lib',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_var_lib_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_var_lib($1)
1ec3d1a
	read_files_pattern($1, policykit_var_lib_t, policykit_var_lib_t)
1ec3d1a
1ec3d1a
	optional_policy(`
1ec3d1a
		# Broken placement
1ec3d1a
		cron_read_system_job_lib_files($1)
1ec3d1a
	')
1ec3d1a
')
1ec3d1a
1ec3d1a
#######################################
1ec3d1a
## <summary>
1ec3d1a
##	The per role template for the policykit module.
1ec3d1a
## </summary>
1ec3d1a
## <param name="user_role">
1ec3d1a
##	<summary>
1ec3d1a
##	Role allowed access
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="user_domain">
1ec3d1a
##	<summary>
1ec3d1a
##	User domain for the role
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
template(`policykit_role',`
1ec3d1a
	policykit_run_auth($2, $1)
1ec3d1a
	policykit_run_grant($2, $1)
1ec3d1a
	policykit_read_lib($2)
1ec3d1a
	policykit_read_reload($2)
1ec3d1a
	policykit_dbus_chat($2)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Send generic signal to policy_auth
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`policykit_signal_auth',`
1ec3d1a
	gen_require(`
1ec3d1a
		type policykit_auth_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 policykit_auth_t:process signal;
1ec3d1a
')