1ec3d1a
policy_module(quota, 1.5.0)
1ec3d1a
1ec3d1a
########################################
1ec3d1a
#
1ec3d1a
# Declarations
1ec3d1a
#
1ec3d1a
1ec3d1a
type quota_t;
1ec3d1a
type quota_exec_t;
1ec3d1a
application_domain(quota_t, quota_exec_t)
1ec3d1a
#init_system_domain(quota_t, quota_exec_t)
1ec3d1a
1ec3d1a
type quota_db_t;
1ec3d1a
files_type(quota_db_t)
1ec3d1a
1ec3d1a
type quota_flag_t;
1ec3d1a
files_type(quota_flag_t)
1ec3d1a
1ec3d1a
type quota_nld_t;
1ec3d1a
type quota_nld_exec_t;
1ec3d1a
init_daemon_domain(quota_nld_t, quota_nld_exec_t)
1ec3d1a
1ec3d1a
type quota_nld_var_run_t;
1ec3d1a
files_pid_file(quota_nld_var_run_t)
1ec3d1a
1ec3d1a
########################################
1ec3d1a
#
1ec3d1a
# Local policy
1ec3d1a
#
1ec3d1a
1ec3d1a
allow quota_t self:capability { sys_admin dac_override };
1ec3d1a
dontaudit quota_t self:capability sys_tty_config;
1ec3d1a
allow quota_t self:process signal_perms;
1ec3d1a
1ec3d1a
# for /quota.*
1ec3d1a
allow quota_t quota_db_t:file { manage_file_perms quotaon };
1ec3d1a
files_root_filetrans(quota_t, quota_db_t, file)
1ec3d1a
files_boot_filetrans(quota_t, quota_db_t, file)
1ec3d1a
files_etc_filetrans(quota_t, quota_db_t, file)
1ec3d1a
files_tmp_filetrans(quota_t, quota_db_t, file)
1ec3d1a
files_home_filetrans(quota_t, quota_db_t, file)
1ec3d1a
files_usr_filetrans(quota_t, quota_db_t, file)
1ec3d1a
files_var_filetrans(quota_t, quota_db_t, file)
1ec3d1a
files_spool_filetrans(quota_t, quota_db_t, file)
1ec3d1a
userdom_user_home_dir_filetrans(quota_t, quota_db_t, file)
1ec3d1a
1ec3d1a
kernel_list_proc(quota_t)
1ec3d1a
kernel_read_proc_symlinks(quota_t)
1ec3d1a
kernel_read_kernel_sysctls(quota_t)
1ec3d1a
kernel_setsched(quota_t)
1ec3d1a
1ec3d1a
dev_read_sysfs(quota_t)
1ec3d1a
dev_getattr_all_blk_files(quota_t)
1ec3d1a
dev_getattr_all_chr_files(quota_t)
1ec3d1a
1ec3d1a
fs_get_xattr_fs_quotas(quota_t)
1ec3d1a
fs_set_xattr_fs_quotas(quota_t)
1ec3d1a
fs_getattr_xattr_fs(quota_t)
1ec3d1a
fs_remount_xattr_fs(quota_t)
1ec3d1a
fs_search_auto_mountpoints(quota_t)
1ec3d1a
1ec3d1a
mls_file_read_all_levels(quota_t)
1ec3d1a
1ec3d1a
storage_raw_read_fixed_disk(quota_t)
1ec3d1a
1ec3d1a
term_dontaudit_use_console(quota_t)
1ec3d1a
1ec3d1a
domain_use_interactive_fds(quota_t)
1ec3d1a
1ec3d1a
files_list_all(quota_t)
1ec3d1a
files_read_all_files(quota_t)
1ec3d1a
files_read_all_symlinks(quota_t)
1ec3d1a
files_getattr_all_pipes(quota_t)
1ec3d1a
files_getattr_all_sockets(quota_t)
1ec3d1a
files_getattr_all_file_type_fs(quota_t)
1ec3d1a
# Read /etc/mtab.
1ec3d1a
files_read_etc_runtime_files(quota_t)
1ec3d1a
1ec3d1a
init_use_fds(quota_t)
1ec3d1a
init_use_script_ptys(quota_t)
1ec3d1a
1ec3d1a
logging_send_syslog_msg(quota_t)
1ec3d1a
0c593c2
mta_spool_filetrans(quota_t, quota_db_t, file)
0c593c2
mta_spool_filetrans_queue(quota_t, quota_db_t, file)
0c593c2
1ec3d1a
userdom_use_inherited_user_terminals(quota_t)
1ec3d1a
userdom_dontaudit_use_unpriv_user_fds(quota_t)
1ec3d1a
1ec3d1a
optional_policy(`
0c593c2
	openshift_lib_filetrans(quota_t, quota_db_t, file)
0c593c2
')
0c593c2
0c593c2
optional_policy(`
1ec3d1a
	seutil_sigchld_newrole(quota_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
optional_policy(`
1ec3d1a
	udev_read_db(quota_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
#######################################
1ec3d1a
#
1ec3d1a
# Local policy
1ec3d1a
#
1ec3d1a
1ec3d1a
allow quota_nld_t self:fifo_file rw_fifo_file_perms;
1ec3d1a
allow quota_nld_t self:netlink_socket create_socket_perms;
1ec3d1a
allow quota_nld_t self:unix_stream_socket create_stream_socket_perms;
1ec3d1a
1ec3d1a
manage_files_pattern(quota_nld_t, quota_nld_var_run_t, quota_nld_var_run_t)
1ec3d1a
files_pid_filetrans(quota_nld_t, quota_nld_var_run_t, { file })
1ec3d1a
1ec3d1a
kernel_read_network_state(quota_nld_t)
1ec3d1a
1ec3d1a
auth_use_nsswitch(quota_nld_t)
1ec3d1a
1ec3d1a
init_read_utmp(quota_nld_t)
1ec3d1a
1ec3d1a
logging_send_syslog_msg(quota_nld_t)
1ec3d1a
1ec3d1a
userdom_use_user_terminals(quota_nld_t)
1ec3d1a
1ec3d1a
optional_policy(`
1ec3d1a
    dbus_system_bus_client(quota_nld_t)
1ec3d1a
    dbus_connect_system_bus(quota_nld_t)
1ec3d1a
')