selinux-refpolicy/policy/modules/apps/cdrecord.if
Kenton Groombridge 99c2c94507 cdrecord, roles: use user exec domain attribute
Signed-off-by: Kenton Groombridge <me@concord.sh>
2021-10-13 19:07:34 -04:00

67 lines
1.3 KiB
Plaintext

## <summary>Record audio or data Compact Discs from a master.</summary>
########################################
## <summary>
## Role access for cdrecord.
## </summary>
## <param name="role_prefix">
## <summary>
## The prefix of the user role (e.g., user
## is the prefix for user_r).
## </summary>
## </param>
## <param name="user_domain">
## <summary>
## User domain for the role.
## </summary>
## </param>
## <param name="user_exec_domain">
## <summary>
## User exec domain for execute and transition access.
## </summary>
## </param>
## <param name="role">
## <summary>
## Role allowed access
## </summary>
## </param>
#
template(`cdrecord_role',`
gen_require(`
attribute_role cdrecord_roles;
type cdrecord_t, cdrecord_exec_t;
')
roleattribute $4 cdrecord_roles;
domtrans_pattern($3, cdrecord_exec_t, cdrecord_t)
allow cdrecord_t $3:unix_stream_socket rw_socket_perms;
allow $3 cdrecord_t:process { ptrace signal_perms };
ps_process_pattern($3, cdrecord_t)
optional_policy(`
systemd_user_app_status($1, cdrecord_t)
')
')
########################################
## <summary>
## Execute cdrecord in the caller domain.
## </summary>
## <param name="domain">
## <summary>
## Domain allowed access.
## </summary>
## </param>
#
interface(`cdrecord_exec',`
gen_require(`
type cdrecord_exec_t;
')
corecmd_search_bin($1)
can_exec($1, cdrecord_exec_t)
')