|
|
1ec3d1a |
policy_module(prelink, 1.10.0)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
########################################
|
|
|
1ec3d1a |
#
|
|
|
1ec3d1a |
# Declarations
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
attribute prelink_object;
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
type prelink_t;
|
|
|
1ec3d1a |
type prelink_exec_t;
|
|
|
1ec3d1a |
init_system_domain(prelink_t, prelink_exec_t)
|
|
|
1ec3d1a |
domain_obj_id_change_exemption(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
type prelink_cache_t;
|
|
|
1ec3d1a |
files_type(prelink_cache_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
type prelink_cron_system_t;
|
|
|
1ec3d1a |
type prelink_cron_system_exec_t;
|
|
|
1ec3d1a |
domain_type(prelink_cron_system_t)
|
|
|
1ec3d1a |
domain_entry_file(prelink_cron_system_t, prelink_cron_system_exec_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
type prelink_log_t;
|
|
|
1ec3d1a |
logging_log_file(prelink_log_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
type prelink_tmp_t;
|
|
|
1ec3d1a |
files_tmp_file(prelink_tmp_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
type prelink_tmpfs_t;
|
|
|
1ec3d1a |
files_tmpfs_file(prelink_tmpfs_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
type prelink_var_lib_t;
|
|
|
1ec3d1a |
files_type(prelink_var_lib_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
########################################
|
|
|
1ec3d1a |
#
|
|
|
1ec3d1a |
# Local policy
|
|
|
1ec3d1a |
#
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
allow prelink_t self:capability { chown dac_override fowner fsetid setfcap sys_resource };
|
|
|
1ec3d1a |
allow prelink_t self:process { execheap execmem execstack signal };
|
|
|
1ec3d1a |
allow prelink_t self:fifo_file rw_fifo_file_perms;
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
allow prelink_t prelink_cache_t:file manage_file_perms;
|
|
|
1ec3d1a |
files_etc_filetrans(prelink_t, prelink_cache_t, file)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
allow prelink_t prelink_log_t:dir setattr;
|
|
|
1ec3d1a |
create_files_pattern(prelink_t, prelink_log_t, prelink_log_t)
|
|
|
1ec3d1a |
append_files_pattern(prelink_t, prelink_log_t, prelink_log_t)
|
|
|
1ec3d1a |
read_lnk_files_pattern(prelink_t, prelink_log_t, prelink_log_t)
|
|
|
1ec3d1a |
logging_log_filetrans(prelink_t, prelink_log_t, file)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
allow prelink_t prelink_tmp_t:file { manage_file_perms execute relabelfrom execmod };
|
|
|
1ec3d1a |
files_tmp_filetrans(prelink_t, prelink_tmp_t, file)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
allow prelink_t prelink_tmpfs_t:file { manage_file_perms execute relabelfrom execmod };
|
|
|
1ec3d1a |
fs_tmpfs_filetrans(prelink_t, prelink_tmpfs_t, file)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
manage_dirs_pattern(prelink_t, prelink_var_lib_t, prelink_var_lib_t)
|
|
|
1ec3d1a |
manage_files_pattern(prelink_t, prelink_var_lib_t, prelink_var_lib_t)
|
|
|
1ec3d1a |
relabel_files_pattern(prelink_t, prelink_var_lib_t, prelink_var_lib_t)
|
|
|
1ec3d1a |
files_var_lib_filetrans(prelink_t, prelink_var_lib_t, { dir file })
|
|
|
1ec3d1a |
files_search_var_lib(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
# prelink misc objects that are not system
|
|
|
1ec3d1a |
# libraries or entrypoints
|
|
|
1ec3d1a |
allow prelink_t prelink_object:file { manage_file_perms execute relabel_file_perms };
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
kernel_read_system_state(prelink_t)
|
|
|
1ec3d1a |
kernel_read_kernel_sysctls(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
corecmd_manage_all_executables(prelink_t)
|
|
|
1ec3d1a |
corecmd_relabel_all_executables(prelink_t)
|
|
|
1ec3d1a |
corecmd_mmap_all_executables(prelink_t)
|
|
|
1ec3d1a |
corecmd_read_bin_symlinks(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
dev_read_urand(prelink_t)
|
|
|
1ec3d1a |
dev_getattr_all_chr_files(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
files_list_all(prelink_t)
|
|
|
1ec3d1a |
files_getattr_all_files(prelink_t)
|
|
|
1ec3d1a |
files_write_non_security_dirs(prelink_t)
|
|
|
1ec3d1a |
files_read_etc_files(prelink_t)
|
|
|
1ec3d1a |
files_read_etc_runtime_files(prelink_t)
|
|
|
1ec3d1a |
files_dontaudit_read_all_symlinks(prelink_t)
|
|
|
1ec3d1a |
files_manage_usr_files(prelink_t)
|
|
|
1ec3d1a |
files_manage_var_files(prelink_t)
|
|
|
1ec3d1a |
files_relabelfrom_usr_files(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
fs_getattr_xattr_fs(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
storage_getattr_fixed_disk_dev(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
selinux_get_enforce_mode(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
libs_exec_ld_so(prelink_t)
|
|
|
1ec3d1a |
libs_legacy_use_shared_libs(prelink_t)
|
|
|
1ec3d1a |
libs_manage_ld_so(prelink_t)
|
|
|
1ec3d1a |
libs_relabel_ld_so(prelink_t)
|
|
|
1ec3d1a |
libs_manage_shared_libs(prelink_t)
|
|
|
1ec3d1a |
libs_relabel_shared_libs(prelink_t)
|
|
|
1ec3d1a |
libs_delete_lib_symlinks(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
miscfiles_read_localization(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
userdom_use_inherited_user_terminals(prelink_t)
|
|
|
1ec3d1a |
userdom_manage_user_home_content(prelink_t)
|
|
|
1ec3d1a |
userdom_relabel_user_home_files(prelink_t)
|
|
|
1ec3d1a |
userdom_execmod_user_home_files(prelink_t)
|
|
|
1ec3d1a |
userdom_exec_user_home_content_files(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
systemd_read_unit_files(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
term_use_all_inherited_terms(prelink_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
amanda_manage_lib(prelink_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
cron_system_entry(prelink_t, prelink_exec_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
gnome_dontaudit_read_config(prelink_t)
|
|
|
1ec3d1a |
gnome_dontaudit_read_inherited_gconf_config_files(prelink_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
mozilla_plugin_manage_rw_files(prelink_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
rpm_manage_tmp_files(prelink_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
unconfined_domain(prelink_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
########################################
|
|
|
1ec3d1a |
#
|
|
|
1ec3d1a |
# Prelink Cron system Policy
|
|
|
1ec3d1a |
#
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
allow prelink_cron_system_t self:capability setuid;
|
|
|
1ec3d1a |
allow prelink_cron_system_t self:process { setsched setfscreate signal };
|
|
|
1ec3d1a |
allow prelink_cron_system_t self:fifo_file rw_fifo_file_perms;
|
|
|
1ec3d1a |
allow prelink_cron_system_t self:unix_dgram_socket { write bind create setopt };
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
read_files_pattern(prelink_cron_system_t, prelink_cache_t, prelink_cache_t)
|
|
|
1ec3d1a |
allow prelink_cron_system_t prelink_cache_t:file unlink;
|
|
|
1ec3d1a |
files_delete_etc_dir_entry(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
domtrans_pattern(prelink_cron_system_t, prelink_exec_t, prelink_t)
|
|
|
1ec3d1a |
allow prelink_cron_system_t prelink_t:process noatsecure;
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
manage_files_pattern(prelink_cron_system_t, prelink_log_t, prelink_log_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
manage_files_pattern(prelink_cron_system_t, prelink_var_lib_t, prelink_var_lib_t)
|
|
|
1ec3d1a |
files_var_lib_filetrans(prelink_cron_system_t, prelink_var_lib_t, file)
|
|
|
1ec3d1a |
allow prelink_cron_system_t prelink_var_lib_t:file { relabelfrom relabelto };
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
kernel_read_system_state(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
corecmd_exec_bin(prelink_cron_system_t)
|
|
|
1ec3d1a |
corecmd_exec_shell(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
files_dontaudit_search_all_mountpoints(prelink_cron_system_t)
|
|
|
1ec3d1a |
files_read_etc_files(prelink_cron_system_t)
|
|
|
1ec3d1a |
files_search_var_lib(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
fs_search_cgroup_dirs(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
auth_use_nsswitch(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
init_telinit(prelink_cron_system_t)
|
|
Chris PeBenito |
9401ae1 |
init_exec(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
libs_exec_ld_so(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
logging_search_logs(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
init_stream_connect(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
miscfiles_read_localization(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
cron_system_entry(prelink_cron_system_t, prelink_cron_system_exec_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
userdom_dontaudit_list_admin_dir(prelink_cron_system_t)
|
|
|
1ec3d1a |
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
rpm_read_db(prelink_cron_system_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
')
|
|
|
bde701d |
|
|
|
1ec3d1a |
ifdef(`hide_broken_symptoms', `
|
|
|
1ec3d1a |
optional_policy(`
|
|
|
1ec3d1a |
dbus_read_config(prelink_t)
|
|
|
1ec3d1a |
')
|
|
|
1ec3d1a |
miscfiles_read_man_pages(prelink_t)
|
|
|
1ec3d1a |
')
|