1ec3d1a
## <summary>device locking policy for lockdev</summary>
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Role access for lockdev
1ec3d1a
## </summary>
1ec3d1a
## <param name="role">
1ec3d1a
##	<summary>
1ec3d1a
##	Role allowed access
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	User domain for the role
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`lockdev_role',`
1ec3d1a
	gen_require(`
1ec3d1a
		type lockdev_t, lockdev_exec_t;
1ec3d1a
		type lockdev_lock_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	role $1 types lockdev_t;
1ec3d1a
1ec3d1a
	# Transition from the user domain to the derived domain.
1ec3d1a
	domtrans_pattern($2, lockdev_exec_t, lockdev_t)
1ec3d1a
	allow lockdev_t $2:process signull;
1ec3d1a
1ec3d1a
	# allow ps to show lockdev
1ec3d1a
	ps_process_pattern($2, lockdev_t)
1ec3d1a
	allow $2 lockdev_t:process signal;
1ec3d1a
')