diff --git a/.gitignore b/.gitignore index 8fea9fc..0dd8fdf 100644 --- a/.gitignore +++ b/.gitignore @@ -224,3 +224,4 @@ serefpolicy* /serefpolicy-3.9.1.tgz /serefpolicy-3.9.2.tgz /serefpolicy-3.9.3.tgz +/serefpolicy-3.9.4.tgz diff --git a/modules-targeted.conf b/modules-targeted.conf index 1a70e73..23d9eb7 100644 --- a/modules-targeted.conf +++ b/modules-targeted.conf @@ -655,6 +655,13 @@ hal = module hddtemp = module # Layer: services +# Module: passenger +# +# Passenger +# +passenger = module + +# Layer: services # Module: policykit # # Hardware abstraction layer diff --git a/nsadiff b/nsadiff index 2383e96..3865f5c 100755 --- a/nsadiff +++ b/nsadiff @@ -1 +1,3 @@ -diff --exclude-from=exclude -N -u -r nsaserefpolicy serefpolicy-3.9.0 > /tmp/diff +cd nsaserefpolicy +git diff origin > /tmp/diff + diff --git a/policy-F14.patch b/policy-F14.patch index b7ea4eb..f47fe9a 100644 --- a/policy-F14.patch +++ b/policy-F14.patch @@ -149,9 +149,34 @@ index 0000000..e9c43b1 +.SH "SEE ALSO" +selinux(8), git(8), chcon(1), semodule(8), setsebool(8) diff --git a/policy/global_tunables b/policy/global_tunables -index 3316f6e..56af226 100644 +index 3316f6e..f85244d 100644 --- a/policy/global_tunables +++ b/policy/global_tunables +@@ -13,21 +13,21 @@ gen_tunable(allow_execheap,false) + + ## + ##

+-## Allow unconfined executables to map a memory region as both executable and writable, this is dangerous and the executable should be reported in bugzilla") ++## Allow unconfined executables to map a memory region as both executable and writable, this is dangerous and the executable should be reported in bugzilla + ##

+ ##
+ gen_tunable(allow_execmem,false) + + ## + ##

+-## Allow all unconfined executables to use libraries requiring text relocation that are not labeled textrel_shlib_t") ++## Allow all unconfined executables to use libraries requiring text relocation that are not labeled textrel_shlib_t + ##

+ ##
+ gen_tunable(allow_execmod,false) + + ## + ##

+-## Allow unconfined executables to make their stack executable. This should never, ever be necessary. Probably indicates a badly coded executable, but could indicate an attack. This executable should be reported in bugzilla") ++## Allow unconfined executables to make their stack executable. This should never, ever be necessary. Probably indicates a badly coded executable, but could indicate an attack. This executable should be reported in bugzilla + ##

+ ##
+ gen_tunable(allow_execstack,false) @@ -61,15 +61,6 @@ gen_tunable(global_ssp,false) ## @@ -206,135 +231,11 @@ index af90ef2..fbd2c40 100644 (( h1 dom h2 ) or ( t1 == mcskillall )); # -diff --git a/policy/modules/admin/amanda.if b/policy/modules/admin/amanda.if -index d1d035e..2cb11ea 100644 ---- a/policy/modules/admin/amanda.if -+++ b/policy/modules/admin/amanda.if -@@ -1,8 +1,9 @@ --## Automated backup program. -+## Advanced Maryland Automatic Network Disk Archiver. - - ######################################## - ## --## Execute amrecover in the amanda_recover domain. -+## Execute a domain transition to -+## run Amanda Recover. - ## - ## - ## -@@ -16,12 +17,15 @@ interface(`amanda_domtrans_recover',` - ') - - domtrans_pattern($1, amanda_recover_exec_t, amanda_recover_t) -+ corecmd_search_bin($1) - ') - - ######################################## - ## --## Execute amrecover in the amanda_recover domain, and --## allow the specified role the amanda_recover domain. -+## Execute a domain transition to -+## run Amanda Recover and allow the -+## specified role the Amanda Recover -+## domain. - ## - ## - ## -@@ -46,7 +50,7 @@ interface(`amanda_run_recover',` - - ######################################## - ## --## Search amanda library directories. -+## Search Amanda lib directories. - ## - ## - ## -@@ -61,11 +65,13 @@ interface(`amanda_search_lib',` - - allow $1 amanda_usr_lib_t:dir search_dir_perms; - files_search_usr($1) -+ libs_search_lib($1) - ') - - ######################################## - ## --## Do not audit attempts to read /etc/dumpdates. -+## Do not audit attempts to read -+## dumpdates files. - ## - ## - ## -@@ -78,12 +84,12 @@ interface(`amanda_dontaudit_read_dumpdates',` - type amanda_dumpdates_t; - ') - -- dontaudit $1 amanda_dumpdates_t:file { getattr read }; -+ dontaudit $1 amanda_dumpdates_t:file read_file_perms; - ') - - ######################################## - ## --## Allow read/writing /etc/dumpdates. -+## Read and write dumpdates files. - ## - ## - ## -@@ -97,11 +103,12 @@ interface(`amanda_rw_dumpdates_files',` - ') - - allow $1 amanda_dumpdates_t:file rw_file_perms; -+ files_search_etc($1) - ') - - ######################################## - ## --## Search amanda library directories. -+## Search Amanda lib directories. - ## - ## - ## -@@ -116,11 +123,12 @@ interface(`amanda_manage_lib',` - - allow $1 amanda_usr_lib_t:dir manage_dir_perms; - files_search_usr($1) -+ libs_search_lib($1) - ') - - ######################################## - ## --## Allow read/writing amanda logs -+## Read and write Amanda logs. - ## - ## - ## -@@ -134,11 +142,12 @@ interface(`amanda_append_log_files',` - ') - - allow $1 amanda_log_t:file { read_file_perms append_file_perms }; -+ logging_search_logs($1) - ') - - ####################################### - ## --## Search amanda var library directories. -+## Search Amanda lib directories. - ## - ## - ## -@@ -151,7 +160,6 @@ interface(`amanda_search_var_lib',` - type amanda_var_lib_t; - ') - -- files_search_var_lib($1) - allow $1 amanda_var_lib_t:dir search_dir_perms; -- -+ files_search_var_lib($1) - ') diff --git a/policy/modules/admin/anaconda.te b/policy/modules/admin/anaconda.te -index 96f68e9..6cf5d7a 100644 +index f76ed8a..9a9526a 100644 --- a/policy/modules/admin/anaconda.te +++ b/policy/modules/admin/anaconda.te -@@ -31,6 +31,7 @@ modutils_domtrans_insmod(anaconda_t) +@@ -30,6 +30,7 @@ modutils_domtrans_insmod(anaconda_t) modutils_domtrans_depmod(anaconda_t) seutil_domtrans_semanage(anaconda_t) @@ -342,7 +243,7 @@ index 96f68e9..6cf5d7a 100644 userdom_user_home_dir_filetrans_user_home_content(anaconda_t, { dir file lnk_file fifo_file sock_file }) -@@ -52,7 +53,7 @@ optional_policy(` +@@ -51,7 +52,7 @@ optional_policy(` ') optional_policy(` @@ -379,10 +280,10 @@ index 5b43db5..fdb453c 100644 + role $2 types brctl_t; +') diff --git a/policy/modules/admin/certwatch.te b/policy/modules/admin/certwatch.te -index 89b9f2a..9cba75f 100644 +index e0fa983..86644f0 100644 --- a/policy/modules/admin/certwatch.te +++ b/policy/modules/admin/certwatch.te -@@ -35,7 +35,7 @@ miscfiles_read_certs(certwatch_t) +@@ -35,7 +35,7 @@ miscfiles_read_generic_certs(certwatch_t) miscfiles_read_localization(certwatch_t) userdom_use_user_terminals(certwatch_t) @@ -1555,7 +1456,7 @@ index 7bddc02..2b59ed0 100644 + +/var/db/sudo(/.*)? gen_context(system_u:object_r:sudo_db_t,s0) diff --git a/policy/modules/admin/sudo.if b/policy/modules/admin/sudo.if -index 5f44f1b..464a11e 100644 +index 5f44f1b..2993130 100644 --- a/policy/modules/admin/sudo.if +++ b/policy/modules/admin/sudo.if @@ -32,6 +32,7 @@ template(`sudo_role_template',` @@ -1593,9 +1494,11 @@ index 5f44f1b..464a11e 100644 auth_run_chk_passwd($1_sudo_t, $2) # sudo stores a token in the pam_pid directory -@@ -134,12 +141,16 @@ template(`sudo_role_template',` +@@ -133,13 +140,18 @@ template(`sudo_role_template',` + userdom_manage_user_tmp_files($1_sudo_t) userdom_manage_user_tmp_symlinks($1_sudo_t) userdom_use_user_terminals($1_sudo_t) ++ userdom_signal_unpriv_users($1_sudo_t) # for some PAM modules and for cwd - userdom_dontaudit_search_user_home_content($1_sudo_t) + userdom_search_user_home_content($1_sudo_t) @@ -1889,10 +1792,10 @@ index 0000000..5ef90cd + diff --git a/policy/modules/apps/chrome.te b/policy/modules/apps/chrome.te new file mode 100644 -index 0000000..90c754f +index 0000000..b09816f --- /dev/null +++ b/policy/modules/apps/chrome.te -@@ -0,0 +1,86 @@ +@@ -0,0 +1,91 @@ +policy_module(chrome,1.0.0) + +######################################## @@ -1933,6 +1836,9 @@ index 0000000..90c754f +kernel_read_system_state(chrome_sandbox_t) +kernel_read_kernel_sysctls(chrome_sandbox_t) + ++fs_manage_cgroup_dirs(chrome_sandbox_t) ++fs_manage_cgroup_files(chrome_sandbox_t) ++ +corecmd_exec_bin(chrome_sandbox_t) + +domain_dontaudit_read_all_domains_state(chrome_sandbox_t) @@ -1955,6 +1861,8 @@ index 0000000..90c754f +miscfiles_read_localization(chrome_sandbox_t) +miscfiles_read_fonts(chrome_sandbox_t) + ++sysnet_dontaudit_read_config(chrome_sandbox_t) ++ +optional_policy(` + execmem_exec(chrome_sandbox_t) +') @@ -2344,7 +2252,7 @@ index 00a19e3..46db5ff 100644 +/usr/libexec/gnome-system-monitor-mechanism -- gen_context(system_u:object_r:gnomesystemmm_exec_t,s0) + diff --git a/policy/modules/apps/gnome.if b/policy/modules/apps/gnome.if -index f5afe78..db1a0d0 100644 +index f5afe78..250935a 100644 --- a/policy/modules/apps/gnome.if +++ b/policy/modules/apps/gnome.if @@ -37,8 +37,7 @@ interface(`gnome_role',` @@ -2357,7 +2265,7 @@ index f5afe78..db1a0d0 100644 ## ## ## -@@ -46,37 +45,36 @@ interface(`gnome_role',` +@@ -46,19 +45,276 @@ interface(`gnome_role',` ## ## # @@ -2380,94 +2288,73 @@ index f5afe78..db1a0d0 100644 ## -## +## - ## - ## Domain allowed access. - ## - ## - # --template(`gnome_read_gconf_config',` ++## ++## Domain allowed access. ++## ++## ++# +interface(`gnome_domtrans_gconfd',` - gen_require(` -- type gconf_etc_t; ++ gen_require(` + type gconfd_t, gconfd_exec_t; - ') - -- allow $1 gconf_etc_t:dir list_dir_perms; -- read_files_pattern($1, gconf_etc_t, gconf_etc_t) -- files_search_etc($1) ++ ') ++ + domtrans_pattern($1, gconfd_exec_t, gconfd_t) - ') - --####################################### ++') ++ +######################################## - ## --## Create, read, write, and delete gconf config files. ++## +## Dontaudit search gnome homedir content (.config) - ## - ## - ## -@@ -84,37 +82,38 @@ template(`gnome_read_gconf_config',` - ## - ## - # --interface(`gnome_manage_gconf_config',` ++## ++## ++## ++## Domain allowed access. ++## ++## ++# +interface(`gnome_dontaudit_search_config',` - gen_require(` -- type gconf_etc_t; ++ gen_require(` + attribute gnome_home_type; - ') - -- manage_files_pattern($1, gconf_etc_t, gconf_etc_t) -- files_search_etc($1) ++ ') ++ + dontaudit $1 gnome_home_type:dir search_dir_perms; - ') - - ######################################## - ## --## gconf connection template. ++') ++ ++######################################## ++## +## manage gnome homedir content (.config) - ## --## ++## +## - ## - ## Domain allowed access. - ## - ## - # --interface(`gnome_stream_connect_gconf',` ++## ++## Domain allowed access. ++## ++## ++# +interface(`gnome_manage_config',` - gen_require(` -- type gconfd_t, gconf_tmp_t; ++ gen_require(` + attribute gnome_home_type; - ') - -- read_files_pattern($1, gconf_tmp_t, gconf_tmp_t) -- allow $1 gconfd_t:unix_stream_socket connectto; ++ ') ++ + allow $1 gnome_home_type:dir manage_dir_perms; + allow $1 gnome_home_type:file manage_file_perms; + allow $1 gnome_home_type:lnk_file manage_lnk_file_perms; + userdom_search_user_home_dirs($1) - ') - - ######################################## - ## --## Run gconfd in gconfd domain. ++') ++ ++######################################## ++## +## Send general signals to all gconf domains. - ## - ## - ## -@@ -122,12 +121,139 @@ interface(`gnome_stream_connect_gconf',` - ## - ## - # --interface(`gnome_domtrans_gconfd',` ++## ++## ++## ++## Domain allowed access. ++## ++## ++# +interface(`gnome_signal_all',` - gen_require(` -- type gconfd_t, gconfd_exec_t; ++ gen_require(` + attribute gnomedomain; - ') - -- domtrans_pattern($1, gconfd_exec_t, gconfd_t) ++ ') ++ + allow $1 gnomedomain:process signal; +') + @@ -2596,14 +2483,10 @@ index f5afe78..db1a0d0 100644 + list_dirs_pattern($1, gnome_home_type, gnome_home_type) + read_files_pattern($1, gnome_home_type, gnome_home_type) + read_lnk_files_pattern($1, gnome_home_type, gnome_home_type) - ') - - ######################################## -@@ -151,40 +277,306 @@ interface(`gnome_setattr_config_dirs',` - - ######################################## - ## --## Read gnome homedir content (.config) ++') ++ ++######################################## ++## +## Create objects in a Gnome gconf home directory +## with an automatic type transition to +## a specified private type. @@ -2659,24 +2542,21 @@ index f5afe78..db1a0d0 100644 +######################################## +## +## read gconf config files - ## ++## +## -+## -+## Domain allowed access. -+## -+## -+# -+template(`gnome_read_gconf_config',` -+ gen_require(` -+ type gconf_etc_t; -+ ') -+ -+ allow $1 gconf_etc_t:dir list_dir_perms; -+ read_files_pattern($1, gconf_etc_t, gconf_etc_t) -+') -+ -+####################################### -+## + ## + ## Domain allowed access. + ## +@@ -71,12 +327,31 @@ template(`gnome_read_gconf_config',` + + allow $1 gconf_etc_t:dir list_dir_perms; + read_files_pattern($1, gconf_etc_t, gconf_etc_t) +- files_search_etc($1) + ') + + ####################################### + ## +-## Create, read, write, and delete gconf config files. +## Manage gconf config files +## +## @@ -2698,84 +2578,109 @@ index f5afe78..db1a0d0 100644 +## +## Execute gconf programs in +## in the caller domain. -+## -+## -+## -+## Domain allowed access. -+## -+## -+# + ## + ## + ## +@@ -84,37 +359,39 @@ template(`gnome_read_gconf_config',` + ## + ## + # +-interface(`gnome_manage_gconf_config',` +interface(`gnome_exec_gconf',` -+ gen_require(` + gen_require(` +- type gconf_etc_t; + type gconfd_exec_t; -+ ') -+ + ') + +- manage_files_pattern($1, gconf_etc_t, gconf_etc_t) +- files_search_etc($1) + can_exec($1, gconfd_exec_t) -+') -+ -+######################################## -+## + ') + + ######################################## + ## +-## gconf connection template. +## Read gconf home files -+## + ## +-## +## -+## -+## Domain allowed access. -+## -+## -+# + ## + ## Domain allowed access. + ## + ## + # +-interface(`gnome_stream_connect_gconf',` +interface(`gnome_read_gconf_home_files',` -+ gen_require(` + gen_require(` +- type gconfd_t, gconf_tmp_t; + type gconf_home_t; + type data_home_t; -+ ') -+ + ') + +- read_files_pattern($1, gconf_tmp_t, gconf_tmp_t) +- allow $1 gconfd_t:unix_stream_socket connectto; + allow $1 gconf_home_t:dir list_dir_perms; + allow $1 data_home_t:dir list_dir_perms; + read_files_pattern($1, gconf_home_t, gconf_home_t) + read_files_pattern($1, data_home_t, data_home_t) -+') -+ -+######################################## -+## + ') + + ######################################## + ## +-## Run gconfd in gconfd domain. +## search gconf homedir (.local) -+## -+## -+## -+## Domain allowed access. -+## -+## -+# + ## + ## + ## +@@ -122,12 +399,13 @@ interface(`gnome_stream_connect_gconf',` + ## + ## + # +-interface(`gnome_domtrans_gconfd',` +interface(`gnome_search_gconf',` -+ gen_require(` + gen_require(` +- type gconfd_t, gconfd_exec_t; + type gconf_home_t; -+ ') -+ + ') + +- domtrans_pattern($1, gconfd_exec_t, gconfd_t) + allow $1 gconf_home_t:dir search_dir_perms; + userdom_search_user_home_dirs($1) -+') -+ -+######################################## -+## + ') + + ######################################## +@@ -151,40 +429,173 @@ interface(`gnome_setattr_config_dirs',` + + ######################################## + ## +-## Read gnome homedir content (.config) +## Append gconf home files -+## + ## +-## +## -+## -+## Domain allowed access. -+## -+## -+# + ## + ## Domain allowed access. + ## + ## + # +-template(`gnome_read_config',` +interface(`gnome_append_gconf_home_files',` -+ gen_require(` + gen_require(` +- type gnome_home_t; + type gconf_home_t; -+ ') -+ + ') + +- list_dirs_pattern($1, gnome_home_t, gnome_home_t) +- read_files_pattern($1, gnome_home_t, gnome_home_t) +- read_lnk_files_pattern($1, gnome_home_t, gnome_home_t) + append_files_pattern($1, gconf_home_t, gconf_home_t) -+') -+ -+######################################## -+## + ') + + ######################################## + ## +-## manage gnome homedir content (.config) +## manage gconf home files -+## + ## +## +## +## Domain allowed access. @@ -2825,21 +2730,39 @@ index f5afe78..db1a0d0 100644 ## ## # --template(`gnome_read_config',` +-interface(`gnome_manage_config',` +template(`gnome_list_home_config',` gen_require(` - type gnome_home_t; + type config_home_t; ') -- list_dirs_pattern($1, gnome_home_t, gnome_home_t) -- read_files_pattern($1, gnome_home_t, gnome_home_t) -- read_lnk_files_pattern($1, gnome_home_t, gnome_home_t) +- allow $1 gnome_home_t:dir manage_dir_perms; +- allow $1 gnome_home_t:file manage_file_perms; + allow $1 config_home_t:dir list_dir_perms; +') + +######################################## +## ++## Set attributes of gnome homedir content (.config) ++## ++## ++## ++## Domain allowed access. ++## ++## ++# ++template(`gnome_setattr_home_config',` ++ gen_require(` ++ type config_home_t; ++ ') ++ ++ setattr_dirs_pattern($1, config_home_t, config_home_t) + userdom_search_user_home_dirs($1) + ') ++ ++######################################## ++## +## read gnome homedir content (.config) +## +## @@ -2854,29 +2777,23 @@ index f5afe78..db1a0d0 100644 + ') + + read_files_pattern($1, config_home_t, config_home_t) - ') - - ######################################## - ## - ## manage gnome homedir content (.config) - ## --## ++') ++ ++######################################## ++## ++## manage gnome homedir content (.config) ++## +## - ## - ## Domain allowed access. - ## - ## - # --interface(`gnome_manage_config',` ++## ++## Domain allowed access. ++## ++## ++# +template(`gnome_manage_home_config',` - gen_require(` -- type gnome_home_t; ++ gen_require(` + type config_home_t; - ') - -- allow $1 gnome_home_t:dir manage_dir_perms; -- allow $1 gnome_home_t:file manage_file_perms; -- userdom_search_user_home_dirs($1) ++ ') ++ + manage_files_pattern($1, config_home_t, config_home_t) +') + @@ -2917,7 +2834,7 @@ index f5afe78..db1a0d0 100644 + + allow $1 gconfdefaultsm_t:dbus send_msg; + allow gconfdefaultsm_t $1:dbus send_msg; - ') ++') diff --git a/policy/modules/apps/gnome.te b/policy/modules/apps/gnome.te index 35f7486..26852d2 100644 --- a/policy/modules/apps/gnome.te @@ -3777,7 +3694,7 @@ index 9a6d67d..47aa143 100644 ## mozilla over dbus. ## diff --git a/policy/modules/apps/mozilla.te b/policy/modules/apps/mozilla.te -index cbf4bec..ec6a1ff 100644 +index cbf4bec..7c260fa 100644 --- a/policy/modules/apps/mozilla.te +++ b/policy/modules/apps/mozilla.te @@ -25,6 +25,7 @@ files_config_file(mozilla_conf_t) @@ -3850,7 +3767,7 @@ index cbf4bec..ec6a1ff 100644 pulseaudio_exec(mozilla_t) pulseaudio_stream_connect(mozilla_t) pulseaudio_manage_home_files(mozilla_t) -@@ -266,3 +291,79 @@ optional_policy(` +@@ -266,3 +291,89 @@ optional_policy(` optional_policy(` thunderbird_domtrans(mozilla_t) ') @@ -3878,6 +3795,8 @@ index cbf4bec..ec6a1ff 100644 +manage_sock_files_pattern(mozilla_plugin_t, mozilla_plugin_tmpfs_t, mozilla_plugin_tmpfs_t) +fs_tmpfs_filetrans(mozilla_plugin_t, mozilla_plugin_tmpfs_t, { file lnk_file sock_file fifo_file }) + ++can_exec(mozilla_plugin_t, mozilla_exec_t) ++ +kernel_read_kernel_sysctls(mozilla_plugin_t) +kernel_read_system_state(mozilla_plugin_t) +kernel_request_load_module(mozilla_plugin_t) @@ -3888,6 +3807,8 @@ index cbf4bec..ec6a1ff 100644 +dev_read_urand(mozilla_plugin_t) +dev_read_video_dev(mozilla_plugin_t) +dev_read_sysfs(mozilla_plugin_t) ++dev_read_sound(mozilla_plugin_t) ++dev_write_sound(mozilla_plugin_t) + +domain_use_interactive_fds(mozilla_plugin_t) +domain_dontaudit_read_all_domains_state(mozilla_plugin_t) @@ -3908,11 +3829,16 @@ index cbf4bec..ec6a1ff 100644 +userdom_dontaudit_use_user_ptys(mozilla_plugin_t) + +optional_policy(` ++ alsa_read_rw_config(mozilla_plugin_t) ++') ++ ++optional_policy(` + dbus_read_lib_files(mozilla_plugin_t) +') + +optional_policy(` + gnome_manage_home_config(mozilla_plugin_t) ++ gnome_setattr_home_config(mozilla_plugin_t) +') + +optional_policy(` @@ -3929,6 +3855,7 @@ index cbf4bec..ec6a1ff 100644 +optional_policy(` + xserver_read_xdm_pid(mozilla_plugin_t) + xserver_stream_connect(mozilla_plugin_t) ++ xserver_use_user_fonts(mozilla_plugin_t) +') diff --git a/policy/modules/apps/mplayer.if b/policy/modules/apps/mplayer.if index d8ea41d..8bdc526 100644 @@ -4430,10 +4357,10 @@ index 0000000..c779d44 +') diff --git a/policy/modules/apps/nsplugin.te b/policy/modules/apps/nsplugin.te new file mode 100644 -index 0000000..23890a7 +index 0000000..7bc0dcf --- /dev/null +++ b/policy/modules/apps/nsplugin.te -@@ -0,0 +1,308 @@ +@@ -0,0 +1,310 @@ +policy_module(nsplugin, 1.0.0) + +######################################## @@ -4499,6 +4426,8 @@ index 0000000..23890a7 +allow nsplugin_t self:unix_stream_socket { connectto create_stream_socket_perms }; +allow nsplugin_t self:unix_dgram_socket create_socket_perms; +allow nsplugin_t nsplugin_rw_t:dir list_dir_perms; ++read_lnk_files_pattern(nsplugin_config_t, nsplugin_rw_t, nsplugin_rw_t) ++read_files_pattern(nsplugin_config_t, nsplugin_rw_t, nsplugin_rw_t) + +tunable_policy(`allow_nsplugin_execmem',` + allow nsplugin_t self:process { execstack execmem }; @@ -4931,7 +4860,7 @@ index 690589e..815d35d 100644 optional_policy(` diff --git a/policy/modules/apps/pulseaudio.if b/policy/modules/apps/pulseaudio.if -index 2ba7787..3b0d3be 100644 +index 2ba7787..15fef11 100644 --- a/policy/modules/apps/pulseaudio.if +++ b/policy/modules/apps/pulseaudio.if @@ -35,6 +35,10 @@ interface(`pulseaudio_role',` @@ -4945,6 +4874,22 @@ index 2ba7787..3b0d3be 100644 allow $2 pulseaudio_t:dbus send_msg; allow pulseaudio_t $2:dbus { acquire_svc send_msg }; ') +@@ -215,6 +219,7 @@ interface(`pulseaudio_read_home_files',` + + userdom_search_user_home_dirs($1) + read_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t) ++ read_lnk_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t) + ') + + ######################################## +@@ -233,6 +238,7 @@ interface(`pulseaudio_rw_home_files',` + ') + + rw_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t) ++ read_lnk_files_pattern($1, pulseaudio_home_t, pulseaudio_home_t) + userdom_search_user_home_dirs($1) + ') + diff --git a/policy/modules/apps/pulseaudio.te b/policy/modules/apps/pulseaudio.te index 5c2680c..db96581 100644 --- a/policy/modules/apps/pulseaudio.te @@ -5186,10 +5131,10 @@ index 0000000..15778fd +# No types are sandbox_exec_t diff --git a/policy/modules/apps/sandbox.if b/policy/modules/apps/sandbox.if new file mode 100644 -index 0000000..c20d303 +index 0000000..5dd356f --- /dev/null +++ b/policy/modules/apps/sandbox.if -@@ -0,0 +1,335 @@ +@@ -0,0 +1,336 @@ + +## policy for sandbox + @@ -5246,6 +5191,7 @@ index 0000000..c20d303 + allow $1 sandbox_tmpfs_type:file manage_file_perms; + dontaudit $1 sandbox_tmpfs_type:file manage_file_perms; + ++ can_exec($1, sandbox_file_type) + manage_files_pattern($1, sandbox_file_type, sandbox_file_type); + manage_dirs_pattern($1, sandbox_file_type, sandbox_file_type); + manage_sock_files_pattern($1, sandbox_file_type, sandbox_file_type); @@ -6269,10 +6215,10 @@ index 0000000..3d12484 +') diff --git a/policy/modules/apps/telepathy.te b/policy/modules/apps/telepathy.te new file mode 100644 -index 0000000..c7250ae +index 0000000..aa34be4 --- /dev/null +++ b/policy/modules/apps/telepathy.te -@@ -0,0 +1,320 @@ +@@ -0,0 +1,318 @@ + +policy_module(telepathy, 1.0.0) + @@ -6345,15 +6291,13 @@ index 0000000..c7250ae +files_read_etc_files(telepathy_msn_t) +files_read_usr_files(telepathy_msn_t) + -+kernel_read_system_state(telepathy_msn_t) -+ +auth_use_nsswitch(telepathy_msn_t) + +libs_exec_ldconfig(telepathy_msn_t) + +logging_send_syslog_msg(telepathy_msn_t) + -+miscfiles_read_certs(telepathy_msn_t) ++miscfiles_read_all_certs(telepathy_msn_t) + +sysnet_read_config(telepathy_msn_t) + @@ -6404,7 +6348,7 @@ index 0000000..c7250ae +files_read_config_files(telepathy_gabble_t) +files_read_usr_files(telepathy_gabble_t) + -+miscfiles_read_certs(telepathy_gabble_t) ++miscfiles_read_all_certs(telepathy_gabble_t) + +sysnet_read_config(telepathy_gabble_t) + @@ -6538,8 +6482,6 @@ index 0000000..c7250ae +files_read_etc_files(telepathy_sunshine_t) +files_read_usr_files(telepathy_sunshine_t) + -+kernel_read_system_state(telepathy_sunshine_t) -+ +optional_policy(` + xserver_read_xdm_pid(telepathy_sunshine_t) + xserver_stream_connect(telepathy_sunshine_t) @@ -6550,7 +6492,7 @@ index 0000000..c7250ae +# telepathy domains common policy +# + -+allow telepathy_domain self:process { getsched signal }; ++allow telepathy_domain self:process { getsched signal sigkill }; +allow telepathy_domain self:fifo_file rw_fifo_file_perms; +allow telepathy_domain self:tcp_socket create_socket_perms; +allow telepathy_domain self:udp_socket create_socket_perms; @@ -6565,6 +6507,8 @@ index 0000000..c7250ae +corenet_tcp_sendrecv_generic_node(telepathy_domain) +corenet_udp_bind_generic_node(telepathy_domain) + ++kernel_read_system_state(telepathy_domain) ++ +fs_search_auto_mountpoints(telepathy_domain) + +miscfiles_read_localization(telepathy_domain) @@ -6914,7 +6858,7 @@ index 82842a0..369c3b5 100644 dbus_system_bus_client($1_wm_t) dbus_session_bus_client($1_wm_t) diff --git a/policy/modules/kernel/corecommands.fc b/policy/modules/kernel/corecommands.fc -index 0eb1d97..b42af1b 100644 +index 0eb1d97..93c9ec1 100644 --- a/policy/modules/kernel/corecommands.fc +++ b/policy/modules/kernel/corecommands.fc @@ -9,8 +9,11 @@ @@ -6948,26 +6892,29 @@ index 0eb1d97..b42af1b 100644 # # /lib # -@@ -126,6 +134,7 @@ ifdef(`distro_gentoo',` +@@ -126,6 +134,8 @@ ifdef(`distro_gentoo',` /lib/rcscripts/net\.modules\.d/helpers\.d/dhclient-.* -- gen_context(system_u:object_r:bin_t,s0) /lib/rcscripts/net\.modules\.d/helpers\.d/udhcpc-.* -- gen_context(system_u:object_r:bin_t,s0) ') ++/lib/readahead(/.*)? gen_context(system_u:object_r:bin_t,s0) +/lib/upstart(/.*)? gen_context(system_u:object_r:bin_t,s0) # # /sbin -@@ -145,6 +154,10 @@ ifdef(`distro_gentoo',` +@@ -145,6 +155,12 @@ ifdef(`distro_gentoo',` /opt/(.*/)?sbin(/.*)? gen_context(system_u:object_r:bin_t,s0) -+/opt/gutenprint/cups/lib/filter(/.*)? gen_context(system_u:object_r:bin_t,s0) ++/opt/google/talkplugin/cron(/.*)? gen_context(system_u:object_r:bin_t,s0) ++ ++/opt/gutenprint/cups/lib/filter(/.*)? gen_context(system_u:object_r:bin_t,s0) + +/opt/OpenPrinting-Gutenprint/cups/lib/filter(/.*)? gen_context(system_u:object_r:bin_t,s0) + ifdef(`distro_gentoo',` /opt/RealPlayer/realplay(\.bin)? gen_context(system_u:object_r:bin_t,s0) /opt/RealPlayer/postint(/.*)? gen_context(system_u:object_r:bin_t,s0) -@@ -169,6 +182,7 @@ ifdef(`distro_gentoo',` +@@ -169,6 +185,7 @@ ifdef(`distro_gentoo',` /usr/lib/fence(/.*)? gen_context(system_u:object_r:bin_t,s0) /usr/lib/pgsql/test/regress/.*\.sh -- gen_context(system_u:object_r:bin_t,s0) /usr/lib/qt.*/bin(/.*)? gen_context(system_u:object_r:bin_t,s0) @@ -6975,7 +6922,7 @@ index 0eb1d97..b42af1b 100644 /usr/lib(64)?/[^/]*firefox[^/]*/firefox -- gen_context(system_u:object_r:bin_t,s0) /usr/lib(64)?/apt/methods.+ -- gen_context(system_u:object_r:bin_t,s0) /usr/lib(64)?/ConsoleKit/scripts(/.*)? gen_context(system_u:object_r:bin_t,s0) -@@ -218,8 +232,11 @@ ifdef(`distro_gentoo',` +@@ -218,8 +235,11 @@ ifdef(`distro_gentoo',` /usr/sbin/sesh -- gen_context(system_u:object_r:shell_exec_t,s0) /usr/sbin/smrsh -- gen_context(system_u:object_r:shell_exec_t,s0) @@ -6987,7 +6934,7 @@ index 0eb1d97..b42af1b 100644 /usr/share/debconf/.+ -- gen_context(system_u:object_r:bin_t,s0) /usr/share/denyhosts/scripts(/.*)? gen_context(system_u:object_r:bin_t,s0) /usr/share/denyhosts/plugins(/.*)? gen_context(system_u:object_r:bin_t,s0) -@@ -228,6 +245,8 @@ ifdef(`distro_gentoo',` +@@ -228,6 +248,8 @@ ifdef(`distro_gentoo',` /usr/share/cluster/svclib_nfslock -- gen_context(system_u:object_r:bin_t,s0) /usr/share/e16/misc(/.*)? gen_context(system_u:object_r:bin_t,s0) /usr/share/gedit-2/plugins/externaltools/tools(/.*)? gen_context(system_u:object_r:bin_t,s0) @@ -6996,7 +6943,7 @@ index 0eb1d97..b42af1b 100644 /usr/share/gnucash/finance-quote-check -- gen_context(system_u:object_r:bin_t,s0) /usr/share/gnucash/finance-quote-helper -- gen_context(system_u:object_r:bin_t,s0) /usr/share/hal/device-manager/hal-device-manager -- gen_context(system_u:object_r:bin_t,s0) -@@ -314,6 +333,7 @@ ifdef(`distro_redhat', ` +@@ -314,6 +336,7 @@ ifdef(`distro_redhat', ` /usr/share/texmf/web2c/mktexdir -- gen_context(system_u:object_r:bin_t,s0) /usr/share/texmf/web2c/mktexnam -- gen_context(system_u:object_r:bin_t,s0) /usr/share/texmf/web2c/mktexupd -- gen_context(system_u:object_r:bin_t,s0) @@ -7004,7 +6951,7 @@ index 0eb1d97..b42af1b 100644 ') ifdef(`distro_suse', ` -@@ -340,3 +360,27 @@ ifdef(`distro_suse', ` +@@ -340,3 +363,27 @@ ifdef(`distro_suse', ` ifdef(`distro_suse',` /var/lib/samba/bin/.+ gen_context(system_u:object_r:bin_t,s0) ') @@ -7585,10 +7532,36 @@ index eb9c360..20c2d34 100644 +allow devices_unconfined_type device_node:{ blk_file chr_file lnk_file } *; allow devices_unconfined_type mtrr_device_t:file *; diff --git a/policy/modules/kernel/domain.if b/policy/modules/kernel/domain.if -index aad8c52..09d4b31 100644 +index aad8c52..0d8458a 100644 --- a/policy/modules/kernel/domain.if +++ b/policy/modules/kernel/domain.if -@@ -611,7 +611,7 @@ interface(`domain_read_all_domains_state',` +@@ -474,6 +474,25 @@ interface(`domain_signal_all_domains',` + + ######################################## + ## ++## Dontaudit sending general signals to all domains. ++## ++## ++## ++## Domain to not audit. ++## ++## ++## ++# ++interface(`domain_dontaudit_signal_all_domains',` ++ gen_require(` ++ attribute domain; ++ ') ++ ++ dontaudit $1 domain:process signal; ++') ++ ++######################################## ++## + ## Send a null signal to all domains. + ## + ## +@@ -611,7 +630,7 @@ interface(`domain_read_all_domains_state',` ######################################## ## @@ -7597,7 +7570,7 @@ index aad8c52..09d4b31 100644 ## ## ## -@@ -630,7 +630,7 @@ interface(`domain_getattr_all_domains',` +@@ -630,7 +649,7 @@ interface(`domain_getattr_all_domains',` ######################################## ## @@ -7606,7 +7579,7 @@ index aad8c52..09d4b31 100644 ## ## ## -@@ -1473,3 +1473,22 @@ interface(`domain_unconfined',` +@@ -1473,3 +1492,22 @@ interface(`domain_unconfined',` typeattribute $1 set_curr_context; typeattribute $1 process_uncond_exempt; ') @@ -8843,7 +8816,7 @@ index 437a42a..8d6d333 100644 +') + diff --git a/policy/modules/kernel/filesystem.te b/policy/modules/kernel/filesystem.te -index 0dff98e..31ebaa7 100644 +index 0dff98e..a09ab47 100644 --- a/policy/modules/kernel/filesystem.te +++ b/policy/modules/kernel/filesystem.te @@ -52,6 +52,7 @@ type anon_inodefs_t; @@ -8871,7 +8844,7 @@ index 0dff98e..31ebaa7 100644 fs_type(hugetlbfs_t) files_mountpoint(hugetlbfs_t) fs_use_trans hugetlbfs gen_context(system_u:object_r:hugetlbfs_t,s0); -+dev_associate_sysfs(hugetlbfs_t) ++dev_associate(hugetlbfs_t) type ibmasmfs_t; fs_type(ibmasmfs_t) @@ -9369,7 +9342,7 @@ index ebe6a9c..e3a1987 100644 ######################################## # diff --git a/policy/modules/roles/staff.te b/policy/modules/roles/staff.te -index 0c9876c..fabc1a0 100644 +index 0c9876c..06b7974 100644 --- a/policy/modules/roles/staff.te +++ b/policy/modules/roles/staff.te @@ -8,17 +8,55 @@ policy_module(staff, 2.1.1) @@ -9428,7 +9401,7 @@ index 0c9876c..fabc1a0 100644 auditadm_role_change(staff_r) ') -@@ -27,6 +65,18 @@ optional_policy(` +@@ -27,6 +65,23 @@ optional_policy(` ') optional_policy(` @@ -9444,10 +9417,15 @@ index 0c9876c..fabc1a0 100644 +') + +optional_policy(` ++ oident_manage_user_content(staff_t) ++ oident_relabel_user_content(staff_t) ++') ++ ++optional_policy(` postgresql_role(staff_r, staff_t) ') -@@ -35,6 +85,18 @@ optional_policy(` +@@ -35,6 +90,18 @@ optional_policy(` ') optional_policy(` @@ -9466,7 +9444,7 @@ index 0c9876c..fabc1a0 100644 ssh_role_template(staff, staff_r, staff_t) ') -@@ -48,6 +110,10 @@ optional_policy(` +@@ -48,6 +115,10 @@ optional_policy(` ') optional_policy(` @@ -9477,7 +9455,18 @@ index 0c9876c..fabc1a0 100644 xserver_role(staff_r, staff_t) ') -@@ -137,10 +203,6 @@ ifndef(`distro_redhat',` +@@ -121,10 +192,6 @@ ifndef(`distro_redhat',` + ') + + optional_policy(` +- oident_manage_user_content(staff_t) +- oident_relabel_user_content(staff_t) +- ') +- optional_policy(` + pyzor_role(staff_r, staff_t) + ') + +@@ -137,10 +204,6 @@ ifndef(`distro_redhat',` ') optional_policy(` @@ -9488,7 +9477,7 @@ index 0c9876c..fabc1a0 100644 spamassassin_role(staff_r, staff_t) ') -@@ -172,3 +234,46 @@ ifndef(`distro_redhat',` +@@ -172,3 +235,46 @@ ifndef(`distro_redhat',` wireshark_role(staff_r, staff_t) ') ') @@ -11365,7 +11354,7 @@ index 0b827c5..8a5d6a4 100644 ## ## All of the rules required to administrate diff --git a/policy/modules/services/abrt.te b/policy/modules/services/abrt.te -index 93d31d5..65609e5 100644 +index 98646c4..2bd70ae 100644 --- a/policy/modules/services/abrt.te +++ b/policy/modules/services/abrt.te @@ -5,6 +5,14 @@ policy_module(abrt, 1.1.1) @@ -11427,7 +11416,7 @@ index 93d31d5..65609e5 100644 logging_read_generic_logs(abrt_t) logging_send_syslog_msg(abrt_t) -@@ -140,6 +151,15 @@ miscfiles_read_certs(abrt_t) +@@ -140,6 +151,15 @@ miscfiles_read_generic_certs(abrt_t) miscfiles_read_localization(abrt_t) userdom_dontaudit_read_user_home_content_files(abrt_t) @@ -11944,7 +11933,7 @@ index adb3d5f..de26af5 100644 ######################################## diff --git a/policy/modules/services/amavis.te b/policy/modules/services/amavis.te -index cf34b4e..cc216a4 100644 +index 3e8002a..31f4612 100644 --- a/policy/modules/services/amavis.te +++ b/policy/modules/services/amavis.te @@ -92,9 +92,10 @@ manage_sock_files_pattern(amavis_t, amavis_var_log_t, amavis_var_log_t) @@ -12488,7 +12477,7 @@ index c9e1a44..2244b11 100644 + dontaudit $1 httpd_t:unix_stream_socket { read write }; ') diff --git a/policy/modules/services/apache.te b/policy/modules/services/apache.te -index e33b9cd..de4388a 100644 +index 08dfa0c..86641dd 100644 --- a/policy/modules/services/apache.te +++ b/policy/modules/services/apache.te @@ -18,6 +18,8 @@ policy_module(apache, 2.2.0) @@ -12521,7 +12510,15 @@ index e33b9cd..de4388a 100644 ## Allow httpd to use built in scripting (usually php) ##

## -@@ -50,6 +66,13 @@ gen_tunable(httpd_can_network_connect, false) +@@ -43,13 +59,20 @@ gen_tunable(httpd_builtin_scripting, false) + + ## + ##

+-## Allow HTTPD scripts and modules to connect to the network using TCP. ++## Allow HTTPD scripts and modules to connect to the network using any TCP port. + ##

+ ##
+ gen_tunable(httpd_can_network_connect, false) ## ##

@@ -12563,6 +12560,15 @@ index e33b9cd..de4388a 100644 ## Allow Apache to communicate with avahi service via dbus ##

##
+@@ -78,7 +115,7 @@ gen_tunable(httpd_dbus_avahi, false) + + ## + ##

+-## Allow httpd cgi support ++## Allow httpd to execute cgi scripts + ##

+ ##
+ gen_tunable(httpd_enable_cgi, false) @@ -100,6 +137,13 @@ gen_tunable(httpd_enable_homedirs, false) ## @@ -12888,10 +12894,16 @@ index e33b9cd..de4388a 100644 ') optional_policy(` -@@ -577,12 +723,23 @@ optional_policy(` +@@ -577,12 +723,29 @@ optional_policy(` ') optional_policy(` ++ passenger_domtrans(httpd_t) ++ passenger_manage_pid_content(httpd_t) ++ passenger_read_lib_files(httpd_t) ++') ++ ++optional_policy(` + rpc_search_nfs_state_data(httpd_t) +') + @@ -12912,7 +12924,7 @@ index e33b9cd..de4388a 100644 ') ') -@@ -591,6 +748,11 @@ optional_policy(` +@@ -591,6 +754,11 @@ optional_policy(` ') optional_policy(` @@ -12924,7 +12936,7 @@ index e33b9cd..de4388a 100644 snmp_dontaudit_read_snmp_var_lib_files(httpd_t) snmp_dontaudit_write_snmp_var_lib_files(httpd_t) ') -@@ -603,6 +765,10 @@ optional_policy(` +@@ -603,6 +771,10 @@ optional_policy(` yam_read_content(httpd_t) ') @@ -12935,7 +12947,7 @@ index e33b9cd..de4388a 100644 ######################################## # # Apache helper local policy -@@ -618,6 +784,10 @@ logging_send_syslog_msg(httpd_helper_t) +@@ -618,6 +790,10 @@ logging_send_syslog_msg(httpd_helper_t) userdom_use_user_terminals(httpd_helper_t) @@ -12946,7 +12958,7 @@ index e33b9cd..de4388a 100644 ######################################## # # Apache PHP script local policy -@@ -699,17 +869,18 @@ manage_dirs_pattern(httpd_suexec_t, httpd_suexec_tmp_t, httpd_suexec_tmp_t) +@@ -699,17 +875,18 @@ manage_dirs_pattern(httpd_suexec_t, httpd_suexec_tmp_t, httpd_suexec_tmp_t) manage_files_pattern(httpd_suexec_t, httpd_suexec_tmp_t, httpd_suexec_tmp_t) files_tmp_filetrans(httpd_suexec_t, httpd_suexec_tmp_t, { file dir }) @@ -12968,7 +12980,7 @@ index e33b9cd..de4388a 100644 files_read_etc_files(httpd_suexec_t) files_read_usr_files(httpd_suexec_t) -@@ -740,10 +911,21 @@ tunable_policy(`httpd_can_network_connect',` +@@ -740,10 +917,21 @@ tunable_policy(`httpd_can_network_connect',` corenet_sendrecv_all_client_packets(httpd_suexec_t) ') @@ -12991,7 +13003,7 @@ index e33b9cd..de4388a 100644 ') tunable_policy(`httpd_enable_homedirs && use_nfs_home_dirs',` -@@ -769,6 +951,12 @@ optional_policy(` +@@ -769,6 +957,12 @@ optional_policy(` dontaudit httpd_suexec_t httpd_t:unix_stream_socket { read write }; ') @@ -13004,7 +13016,7 @@ index e33b9cd..de4388a 100644 ######################################## # # Apache system script local policy -@@ -792,9 +980,13 @@ kernel_read_kernel_sysctls(httpd_sys_script_t) +@@ -792,9 +986,13 @@ kernel_read_kernel_sysctls(httpd_sys_script_t) files_search_var_lib(httpd_sys_script_t) files_search_spool(httpd_sys_script_t) @@ -13018,7 +13030,7 @@ index e33b9cd..de4388a 100644 ifdef(`distro_redhat',` allow httpd_sys_script_t httpd_log_t:file append_file_perms; ') -@@ -803,6 +995,28 @@ tunable_policy(`httpd_can_sendmail',` +@@ -803,6 +1001,28 @@ tunable_policy(`httpd_can_sendmail',` mta_send_mail(httpd_sys_script_t) ') @@ -13047,7 +13059,7 @@ index e33b9cd..de4388a 100644 tunable_policy(`httpd_enable_cgi && httpd_can_network_connect',` allow httpd_sys_script_t self:tcp_socket create_stream_socket_perms; allow httpd_sys_script_t self:udp_socket create_socket_perms; -@@ -830,6 +1044,16 @@ tunable_policy(`httpd_enable_homedirs && use_nfs_home_dirs',` +@@ -830,6 +1050,16 @@ tunable_policy(`httpd_enable_homedirs && use_nfs_home_dirs',` fs_read_nfs_symlinks(httpd_sys_script_t) ') @@ -13064,7 +13076,7 @@ index e33b9cd..de4388a 100644 tunable_policy(`httpd_enable_homedirs && use_samba_home_dirs',` fs_read_cifs_files(httpd_sys_script_t) fs_read_cifs_symlinks(httpd_sys_script_t) -@@ -842,6 +1066,7 @@ optional_policy(` +@@ -842,6 +1072,7 @@ optional_policy(` optional_policy(` mysql_stream_connect(httpd_sys_script_t) mysql_rw_db_sockets(httpd_sys_script_t) @@ -13072,7 +13084,7 @@ index e33b9cd..de4388a 100644 ') optional_policy(` -@@ -891,11 +1116,33 @@ optional_policy(` +@@ -891,11 +1122,33 @@ optional_policy(` tunable_policy(`httpd_enable_cgi && httpd_unified',` allow httpd_user_script_t httpdcontent:file entrypoint; @@ -13223,10 +13235,10 @@ index b9e94c4..608e3a1 100644 ') diff --git a/policy/modules/services/automount.te b/policy/modules/services/automount.te -index a3eaf94..ac13727 100644 +index 39799db..6189565 100644 --- a/policy/modules/services/automount.te +++ b/policy/modules/services/automount.te -@@ -145,6 +145,7 @@ miscfiles_read_certs(automount_t) +@@ -145,6 +145,7 @@ miscfiles_read_generic_certs(automount_t) # Run mount in the mount_t domain. mount_domtrans(automount_t) @@ -13247,7 +13259,7 @@ index 210ca0b..e51354d 100644 allow avahi_t $1:dbus send_msg; ') diff --git a/policy/modules/services/avahi.te b/policy/modules/services/avahi.te -index e4c76d0..0aa1998 100644 +index b7bf6f0..803adbf 100644 --- a/policy/modules/services/avahi.te +++ b/policy/modules/services/avahi.te @@ -37,10 +37,11 @@ manage_dirs_pattern(avahi_t, avahi_var_lib_t, avahi_var_lib_t) @@ -13318,7 +13330,7 @@ index 44a1e3d..71f5514 100644 files_list_pids($1) admin_pattern($1, named_var_run_t) diff --git a/policy/modules/services/bind.te b/policy/modules/services/bind.te -index 2be1518..190b0bc 100644 +index 4deca04..ece1f1f 100644 --- a/policy/modules/services/bind.te +++ b/policy/modules/services/bind.te @@ -89,9 +89,10 @@ manage_dirs_pattern(named_t, named_tmp_t, named_tmp_t) @@ -13580,7 +13592,7 @@ index 0000000..9f4885c +') diff --git a/policy/modules/services/boinc.te b/policy/modules/services/boinc.te new file mode 100644 -index 0000000..62a48ac +index 0000000..aaf0ba3 --- /dev/null +++ b/policy/modules/services/boinc.te @@ -0,0 +1,153 @@ @@ -13685,7 +13697,7 @@ index 0000000..62a48ac +term_dontaudit_getattr_ptmx(boinc_t) + +miscfiles_read_localization(boinc_t) -+miscfiles_read_certs(boinc_t) ++miscfiles_read_generic_certs(boinc_t) + +logging_send_syslog_msg(boinc_t) + @@ -14162,7 +14174,7 @@ index 4c90b57..bffe6b6 100644 unconfined_use_fds(ccs_t) ') diff --git a/policy/modules/services/certmaster.if b/policy/modules/services/certmaster.if -index 27fe7ca..221ea9e 100644 +index 9629d3d..f9335fb 100644 --- a/policy/modules/services/certmaster.if +++ b/policy/modules/services/certmaster.if @@ -18,6 +18,25 @@ interface(`certmaster_domtrans',` @@ -14192,7 +14204,7 @@ index 27fe7ca..221ea9e 100644 ## ## read certmaster logs. diff --git a/policy/modules/services/certmaster.te b/policy/modules/services/certmaster.te -index 1573914..6e32117 100644 +index d8b8639..da60c93 100644 --- a/policy/modules/services/certmaster.te +++ b/policy/modules/services/certmaster.te @@ -60,6 +60,7 @@ corenet_tcp_bind_generic_node(certmaster_t) @@ -14219,7 +14231,7 @@ index a3728d4..7a6e5ba 100644 + admin_pattern($1, certmonger_var_run_t) ') diff --git a/policy/modules/services/certmonger.te b/policy/modules/services/certmonger.te -index 9e83ed7..52312f5 100644 +index 7106981..261a37c 100644 --- a/policy/modules/services/certmonger.te +++ b/policy/modules/services/certmonger.te @@ -68,5 +68,5 @@ optional_policy(` @@ -15172,24 +15184,10 @@ index 3a6d7eb..2098ee9 100644 /var/lib/corosync(/.*)? gen_context(system_u:object_r:corosync_var_lib_t,s0) diff --git a/policy/modules/services/corosync.te b/policy/modules/services/corosync.te -index 7d2cf85..9d97456 100644 +index 7d2cf85..fdb0dcb 100644 --- a/policy/modules/services/corosync.te +++ b/policy/modules/services/corosync.te -@@ -5,6 +5,13 @@ policy_module(corosync, 1.0.0) - # Declarations - # - -+## -+##

-+## Allow corosync to read and write generic tmpfs files. -+##

-+##
-+gen_tunable(allow_corosync_rw_tmpfs, false) -+ - type corosync_t; - type corosync_exec_t; - init_daemon_domain(corosync_t, corosync_exec_t) -@@ -32,8 +39,8 @@ files_pid_file(corosync_var_run_t) +@@ -32,8 +32,8 @@ files_pid_file(corosync_var_run_t) # corosync local policy # @@ -15200,7 +15198,7 @@ index 7d2cf85..9d97456 100644 allow corosync_t self:fifo_file rw_fifo_file_perms; allow corosync_t self:sem create_sem_perms; -@@ -41,6 +48,8 @@ allow corosync_t self:unix_stream_socket { create_stream_socket_perms connectto +@@ -41,6 +41,8 @@ allow corosync_t self:unix_stream_socket { create_stream_socket_perms connectto allow corosync_t self:unix_dgram_socket create_socket_perms; allow corosync_t self:udp_socket create_socket_perms; @@ -15209,7 +15207,7 @@ index 7d2cf85..9d97456 100644 manage_dirs_pattern(corosync_t, corosync_tmp_t, corosync_tmp_t) manage_files_pattern(corosync_t, corosync_tmp_t, corosync_tmp_t) files_tmp_filetrans(corosync_t, corosync_tmp_t, { file dir }) -@@ -63,8 +72,10 @@ manage_sock_files_pattern(corosync_t, corosync_var_run_t, corosync_var_run_t) +@@ -63,8 +65,10 @@ manage_sock_files_pattern(corosync_t, corosync_var_run_t, corosync_var_run_t) files_pid_filetrans(corosync_t, corosync_var_run_t, { file sock_file }) kernel_read_system_state(corosync_t) @@ -15220,7 +15218,7 @@ index 7d2cf85..9d97456 100644 corenet_udp_bind_netsupport_port(corosync_t) -@@ -73,6 +84,7 @@ dev_read_urand(corosync_t) +@@ -73,6 +77,7 @@ dev_read_urand(corosync_t) domain_read_all_domains_state(corosync_t) files_manage_mounttab(corosync_t) @@ -15228,18 +15226,23 @@ index 7d2cf85..9d97456 100644 auth_use_nsswitch(corosync_t) -@@ -83,19 +95,30 @@ logging_send_syslog_msg(corosync_t) +@@ -83,19 +88,35 @@ logging_send_syslog_msg(corosync_t) miscfiles_read_localization(corosync_t) +userdom_delete_user_tmpfs_files(corosync_t) userdom_rw_user_tmpfs_files(corosync_t) -+tunable_policy(`allow_corosync_rw_tmpfs',` -+ fs_rw_tmpfs_files(corosync_t) + optional_policy(` ++ gen_require(` ++ attribute unconfined_services; ++ ') ++ ++ fs_manage_tmpfs_files(corosync_t) ++ init_manage_script_status_files(corosync_t) +') + - optional_policy(` ++optional_policy(` ccs_read_config(corosync_t) ') @@ -16023,7 +16026,7 @@ index 346f926..1f789f8 100644 kernel_read_system_state(cyphesis_t) kernel_read_kernel_sysctls(cyphesis_t) diff --git a/policy/modules/services/cyrus.te b/policy/modules/services/cyrus.te -index 2a0f1c1..ab82c3c 100644 +index e182bf4..f80e725 100644 --- a/policy/modules/services/cyrus.te +++ b/policy/modules/services/cyrus.te @@ -26,7 +26,7 @@ files_pid_file(cyrus_var_run_t) @@ -16162,7 +16165,7 @@ index 39e901a..87fc055 100644 +') + diff --git a/policy/modules/services/dbus.te b/policy/modules/services/dbus.te -index b738e94..4b3d9c4 100644 +index b354128..c725cae 100644 --- a/policy/modules/services/dbus.te +++ b/policy/modules/services/dbus.te @@ -74,9 +74,10 @@ files_tmp_filetrans(system_dbusd_t, system_dbusd_tmp_t, { file dir }) @@ -16485,7 +16488,7 @@ index e1d7dc5..09f6f30 100644 admin_pattern($1, dovecot_var_run_t) diff --git a/policy/modules/services/dovecot.te b/policy/modules/services/dovecot.te -index 14c6a2e..c771d46 100644 +index cbe14e4..64bc566 100644 --- a/policy/modules/services/dovecot.te +++ b/policy/modules/services/dovecot.te @@ -18,7 +18,7 @@ type dovecot_auth_tmp_t; @@ -16497,7 +16500,17 @@ index 14c6a2e..c771d46 100644 type dovecot_deliver_t; type dovecot_deliver_exec_t; -@@ -58,7 +58,7 @@ files_pid_file(dovecot_var_run_t) +@@ -26,6 +26,9 @@ domain_type(dovecot_deliver_t) + domain_entry_file(dovecot_deliver_t, dovecot_deliver_exec_t) + role system_r types dovecot_deliver_t; + ++type dovecot_deliver_tmp_t; ++files_tmp_file(dovecot_deliver_tmp_t) ++ + type dovecot_etc_t; + files_config_file(dovecot_etc_t) + +@@ -58,7 +61,7 @@ files_pid_file(dovecot_var_run_t) allow dovecot_t self:capability { dac_override dac_read_search chown kill net_bind_service setgid setuid sys_chroot }; dontaudit dovecot_t self:capability sys_tty_config; @@ -16506,7 +16519,7 @@ index 14c6a2e..c771d46 100644 allow dovecot_t self:fifo_file rw_fifo_file_perms; allow dovecot_t self:tcp_socket create_stream_socket_perms; allow dovecot_t self:unix_dgram_socket create_socket_perms; -@@ -72,7 +72,8 @@ allow dovecot_t dovecot_cert_t:dir list_dir_perms; +@@ -72,7 +75,8 @@ allow dovecot_t dovecot_cert_t:dir list_dir_perms; read_files_pattern(dovecot_t, dovecot_cert_t, dovecot_cert_t) read_lnk_files_pattern(dovecot_t, dovecot_cert_t, dovecot_cert_t) @@ -16516,7 +16529,7 @@ index 14c6a2e..c771d46 100644 files_search_etc(dovecot_t) can_exec(dovecot_t, dovecot_exec_t) -@@ -94,10 +95,11 @@ manage_dirs_pattern(dovecot_t, dovecot_spool_t, dovecot_spool_t) +@@ -94,10 +98,11 @@ manage_dirs_pattern(dovecot_t, dovecot_spool_t, dovecot_spool_t) manage_files_pattern(dovecot_t, dovecot_spool_t, dovecot_spool_t) manage_lnk_files_pattern(dovecot_t, dovecot_spool_t, dovecot_spool_t) @@ -16529,7 +16542,7 @@ index 14c6a2e..c771d46 100644 kernel_read_kernel_sysctls(dovecot_t) kernel_read_system_state(dovecot_t) -@@ -159,6 +161,11 @@ optional_policy(` +@@ -159,6 +164,11 @@ optional_policy(` ') optional_policy(` @@ -16541,7 +16554,7 @@ index 14c6a2e..c771d46 100644 postgresql_stream_connect(dovecot_t) ') -@@ -242,6 +249,7 @@ optional_policy(` +@@ -242,6 +252,7 @@ optional_policy(` ') optional_policy(` @@ -16549,7 +16562,7 @@ index 14c6a2e..c771d46 100644 postfix_search_spool(dovecot_auth_t) ') -@@ -253,19 +261,27 @@ allow dovecot_deliver_t self:unix_dgram_socket create_socket_perms; +@@ -253,19 +264,31 @@ allow dovecot_deliver_t self:unix_dgram_socket create_socket_perms; allow dovecot_deliver_t dovecot_t:process signull; @@ -16561,6 +16574,10 @@ index 14c6a2e..c771d46 100644 + +append_files_pattern(dovecot_deliver_t, dovecot_var_log_t, dovecot_var_log_t) + ++manage_dirs_pattern(dovecot_deliver_t, dovecot_deliver_tmp_t, dovecot_deliver_tmp_t) ++manage_files_pattern(dovecot_deliver_t, dovecot_deliver_tmp_t, dovecot_deliver_tmp_t) ++files_tmp_filetrans(dovecot_deliver_t, dovecot_deliver_tmp_t, { file dir }) ++ +can_exec(dovecot_deliver_t, dovecot_deliver_exec_t) + kernel_read_all_sysctls(dovecot_deliver_t) @@ -16579,7 +16596,7 @@ index 14c6a2e..c771d46 100644 miscfiles_read_localization(dovecot_deliver_t) -@@ -302,4 +318,5 @@ tunable_policy(`use_samba_home_dirs',` +@@ -302,4 +325,5 @@ tunable_policy(`use_samba_home_dirs',` optional_policy(` mta_manage_spool(dovecot_deliver_t) @@ -16673,7 +16690,7 @@ index 6bef7f8..0217906 100644 + admin_pattern($1, exim_var_run_t) +') diff --git a/policy/modules/services/exim.te b/policy/modules/services/exim.te -index db36bfa..b55c438 100644 +index f28f64b..6c819a3 100644 --- a/policy/modules/services/exim.te +++ b/policy/modules/services/exim.te @@ -35,6 +35,9 @@ mta_mailserver_user_agent(exim_t) @@ -16751,7 +16768,7 @@ index 2a69e5e..fd30b02 100644 iptables_domtrans(fail2ban_t) ') diff --git a/policy/modules/services/fetchmail.te b/policy/modules/services/fetchmail.te -index c92403b..f50e0f1 100644 +index dc2c044..5f5b57b 100644 --- a/policy/modules/services/fetchmail.te +++ b/policy/modules/services/fetchmail.te @@ -37,8 +37,9 @@ allow fetchmail_t fetchmail_etc_t:file read_file_perms; @@ -16766,9 +16783,21 @@ index c92403b..f50e0f1 100644 kernel_read_kernel_sysctls(fetchmail_t) kernel_list_proc(fetchmail_t) diff --git a/policy/modules/services/fprintd.te b/policy/modules/services/fprintd.te -index 7df52c7..54fada0 100644 +index 7df52c7..899feaf 100644 --- a/policy/modules/services/fprintd.te +++ b/policy/modules/services/fprintd.te +@@ -17,9 +17,9 @@ files_type(fprintd_var_lib_t) + # Local policy + # + +-allow fprintd_t self:capability sys_ptrace; ++allow fprintd_t self:capability { sys_nice sys_ptrace }; + allow fprintd_t self:fifo_file rw_fifo_file_perms; +-allow fprintd_t self:process { getsched signal }; ++allow fprintd_t self:process { getsched setsched signal }; + + manage_dirs_pattern(fprintd_t, fprintd_var_lib_t, fprintd_var_lib_t) + manage_files_pattern(fprintd_t, fprintd_var_lib_t, fprintd_var_lib_t) @@ -54,4 +54,5 @@ optional_policy(` policykit_read_lib(fprintd_t) policykit_dbus_chat(fprintd_t) @@ -17673,6 +17702,15 @@ index 7382f85..cf17085 100644 +git_role_template(git_shell) +gen_user(git_shell_u, user, git_shell_r, s0, s0) + +diff --git a/policy/modules/services/gnomeclock.fc b/policy/modules/services/gnomeclock.fc +index 462de63..a8ce02e 100644 +--- a/policy/modules/services/gnomeclock.fc ++++ b/policy/modules/services/gnomeclock.fc +@@ -1,2 +1,4 @@ + /usr/libexec/gnome-clock-applet-mechanism -- gen_context(system_u:object_r:gnomeclock_exec_t,s0) + ++/usr/libexec/gsd-datetime-mechanism -- gen_context(system_u:object_r:gnomeclock_exec_t,s0) ++ diff --git a/policy/modules/services/gnomeclock.if b/policy/modules/services/gnomeclock.if index 671d8fd..da0e844 100644 --- a/policy/modules/services/gnomeclock.if @@ -18255,7 +18293,7 @@ index 3525d24..e5db539 100644 /etc/rc\.d/init\.d/krb524d -- gen_context(system_u:object_r:kerberos_initrc_exec_t,s0) /etc/rc\.d/init\.d/krb5kdc -- gen_context(system_u:object_r:kerberos_initrc_exec_t,s0) diff --git a/policy/modules/services/kerberos.te b/policy/modules/services/kerberos.te -index 8edc29b..6deff48 100644 +index 8edc29b..225e33f 100644 --- a/policy/modules/services/kerberos.te +++ b/policy/modules/services/kerberos.te @@ -126,10 +126,13 @@ corenet_udp_sendrecv_all_ports(kadmind_t) @@ -18276,7 +18314,7 @@ index 8edc29b..6deff48 100644 logging_send_syslog_msg(kadmind_t) -+miscfiles_read_certs(kadmind_t) ++miscfiles_read_generic_certs(kadmind_t) miscfiles_read_localization(kadmind_t) seutil_read_file_contexts(kadmind_t) @@ -18294,7 +18332,7 @@ index 8edc29b..6deff48 100644 logging_send_syslog_msg(krb5kdc_t) -+miscfiles_read_certs(krb5kdc_t) ++miscfiles_read_generic_certs(krb5kdc_t) miscfiles_read_localization(krb5kdc_t) seutil_read_file_contexts(krb5kdc_t) @@ -18487,7 +18525,7 @@ index 3aa8fa7..e5684f4 100644 ######################################## diff --git a/policy/modules/services/ldap.te b/policy/modules/services/ldap.te -index ffa96c6..a715c65 100644 +index 64fd1ff..ee5e345 100644 --- a/policy/modules/services/ldap.te +++ b/policy/modules/services/ldap.te @@ -10,7 +10,7 @@ type slapd_exec_t; @@ -20477,7 +20515,7 @@ index 2324d9e..1a1bfe4 100644 + append_files_pattern($1, NetworkManager_log_t, NetworkManager_log_t) +') diff --git a/policy/modules/services/networkmanager.te b/policy/modules/services/networkmanager.te -index 442cff9..45ecee3 100644 +index 0619395..02ae4e0 100644 --- a/policy/modules/services/networkmanager.te +++ b/policy/modules/services/networkmanager.te @@ -35,7 +35,7 @@ init_system_domain(wpa_cli_t, wpa_cli_exec_t) @@ -20948,7 +20986,7 @@ index 4996f62..975deca 100644 kernel_read_kernel_sysctls(openct_t) kernel_list_proc(openct_t) diff --git a/policy/modules/services/openvpn.te b/policy/modules/services/openvpn.te -index f3d5790..80161cd 100644 +index 8b550f4..ba7c06b 100644 --- a/policy/modules/services/openvpn.te +++ b/policy/modules/services/openvpn.te @@ -24,6 +24,9 @@ files_config_file(openvpn_etc_t) @@ -20992,7 +21030,7 @@ index f3d5790..80161cd 100644 corecmd_exec_bin(openvpn_t) corecmd_exec_shell(openvpn_t) -@@ -113,9 +121,11 @@ sysnet_manage_config(openvpn_t) +@@ -113,19 +121,19 @@ sysnet_manage_config(openvpn_t) sysnet_etc_filetrans_config(openvpn_t) userdom_use_user_terminals(openvpn_t) @@ -21005,7 +21043,17 @@ index f3d5790..80161cd 100644 ') tunable_policy(`openvpn_enable_homedirs && use_nfs_home_dirs',` -@@ -138,3 +148,7 @@ optional_policy(` + fs_read_nfs_files(openvpn_t) +- fs_read_nfs_symlinks(openvpn_t) + ') + + tunable_policy(`openvpn_enable_homedirs && use_samba_home_dirs',` + fs_read_cifs_files(openvpn_t) +- fs_read_cifs_symlinks(openvpn_t) + ') + + optional_policy(` +@@ -138,3 +146,7 @@ optional_policy(` networkmanager_dbus_chat(openvpn_t) ') @@ -21013,6 +21061,167 @@ index f3d5790..80161cd 100644 +optional_policy(` + unconfined_attach_tun_iface(openvpn_t) +') +diff --git a/policy/modules/services/passenger.fc b/policy/modules/services/passenger.fc +new file mode 100644 +index 0000000..8d00972 +--- /dev/null ++++ b/policy/modules/services/passenger.fc +@@ -0,0 +1,6 @@ ++ ++/usr/lib(64)?/ruby/gems/.*/passenger-.*/ext/apache2/ApplicationPoolServerExecutable -- gen_context(system_u:object_r:passenger_exec_t,s0) ++ ++/var/lib/passenger(/.*)? gen_context(system_u:object_r:passenger_var_lib_t,s0) ++ ++/var/run/passenger(/.*)? gen_context(system_u:object_r:passenger_var_run_t,s0) +diff --git a/policy/modules/services/passenger.if b/policy/modules/services/passenger.if +new file mode 100644 +index 0000000..7ca90f6 +--- /dev/null ++++ b/policy/modules/services/passenger.if +@@ -0,0 +1,69 @@ ++## Passenger policy ++ ++###################################### ++## ++## Execute passenger in the passenger domain. ++## ++## ++## ++## The type of the process performing this action. ++## ++## ++# ++interface(`passenger_domtrans',` ++ gen_require(` ++ type passenger_t; ++ type passenger_exec_t; ++ ') ++ ++ allow $1 self:capability { fowner fsetid }; ++ ++ allow $1 passenger_t:process signal; ++ ++ domtrans_pattern($1, passenger_exec_t, passenger_t) ++ allow $1 passenger_t:unix_stream_socket { read write shutdown }; ++ allow passenger_t $1:unix_stream_socket { read write }; ++') ++ ++###################################### ++## ++## Manage passenger var_run content. ++## ++## ++## ++## Domain allowed access. ++## ++## ++# ++interface(`passenger_manage_pid_content',` ++ gen_require(` ++ type passenger_var_run_t; ++ ') ++ ++ files_search_pids($1) ++ manage_dirs_pattern($1, passenger_var_run_t, passenger_var_run_t) ++ manage_files_pattern($1, passenger_var_run_t, passenger_var_run_t) ++ manage_fifo_files_pattern($1, passenger_var_run_t, passenger_var_run_t) ++ manage_sock_files_pattern($1, passenger_var_run_t, passenger_var_run_t) ++') ++ ++######################################## ++## ++## Read passenger lib files ++## ++## ++## ++## Domain to not audit. ++## ++## ++# ++interface(`passenger_read_lib_files',` ++ gen_require(` ++ type passenger_var_lib_t; ++ ') ++ ++ files_search_var_lib($1) ++ read_files_pattern($1, passenger_var_lib_t, passenger_var_lib_t) ++ read_lnk_files_pattern($1, passenger_var_lib_t, passenger_var_lib_t) ++') ++ +diff --git a/policy/modules/services/passenger.te b/policy/modules/services/passenger.te +new file mode 100644 +index 0000000..9cb0d1c +--- /dev/null ++++ b/policy/modules/services/passenger.te +@@ -0,0 +1,68 @@ ++ ++policy_module(passanger,1.0.0) ++ ++######################################## ++# ++# Declarations ++# ++ ++type passenger_t; ++type passenger_exec_t; ++domain_type(passenger_t) ++domain_entry_file(passenger_t, passenger_exec_t) ++role system_r types passenger_t; ++ ++type passenger_tmp_t; ++files_tmp_file(passenger_tmp_t) ++ ++type passenger_var_lib_t; ++files_type(passenger_var_lib_t) ++ ++type passenger_var_run_t; ++files_pid_file(passenger_var_run_t) ++ ++permissive passenger_t; ++ ++######################################## ++# ++# passanger local policy ++# ++ ++allow passenger_t self:capability { dac_override fsetid fowner chown setuid setgid }; ++allow passenger_t self:process signal; ++ ++allow passenger_t self:fifo_file rw_fifo_file_perms; ++allow passenger_t self:unix_stream_socket { create_stream_socket_perms connectto }; ++ ++files_search_var_lib(passenger_t) ++manage_dirs_pattern(passenger_t, passenger_var_lib_t, passenger_var_lib_t) ++manage_files_pattern(passenger_t, passenger_var_lib_t, passenger_var_lib_t) ++ ++manage_dirs_pattern(passenger_t, passenger_var_run_t, passenger_var_run_t) ++manage_files_pattern(passenger_t, passenger_var_run_t, passenger_var_run_t) ++manage_fifo_files_pattern(passenger_t, passenger_var_run_t, passenger_var_run_t) ++manage_sock_files_pattern(passenger_t, passenger_var_run_t, passenger_var_run_t) ++files_pid_filetrans(passenger_t, passenger_var_run_t, { file dir sock_file }) ++ ++kernel_read_system_state(passenger_t) ++kernel_read_kernel_sysctls(passenger_t) ++ ++corenet_tcp_connect_http_port(passenger_t) ++ ++corecmd_exec_bin(passenger_t) ++corecmd_exec_shell(passenger_t) ++ ++dev_read_urand(passenger_t) ++ ++files_read_etc_files(passenger_t) ++ ++auth_use_nsswitch(passenger_t) ++ ++miscfiles_read_localization(passenger_t) ++ ++userdom_dontaudit_use_user_terminals(passenger_t) ++ ++optional_policy(` ++ apache_append_log(passenger_t) ++ apache_read_sys_content(passenger_t) ++') diff --git a/policy/modules/services/pcscd.te b/policy/modules/services/pcscd.te index b881672..da06e9f 100644 --- a/policy/modules/services/pcscd.te @@ -22025,7 +22234,7 @@ index 55e62d2..c114a40 100644 /usr/sbin/postfix -- gen_context(system_u:object_r:postfix_master_exec_t,s0) /usr/sbin/postkick -- gen_context(system_u:object_r:postfix_master_exec_t,s0) diff --git a/policy/modules/services/postfix.if b/policy/modules/services/postfix.if -index c48b45b..18996a5 100644 +index 46bee12..b6d763d 100644 --- a/policy/modules/services/postfix.if +++ b/policy/modules/services/postfix.if @@ -77,6 +77,7 @@ template(`postfix_domain_template',` @@ -23216,7 +23425,7 @@ index 0000000..cf9a327 + +sysnet_dns_name_resolve(qpidd_t) diff --git a/policy/modules/services/radius.te b/policy/modules/services/radius.te -index c53f222..df6769b 100644 +index db6296a..b3f1fd3 100644 --- a/policy/modules/services/radius.te +++ b/policy/modules/services/radius.te @@ -36,7 +36,7 @@ files_pid_file(radiusd_var_run_t) @@ -24059,7 +24268,7 @@ index cda37bb..b0eac5b 100644 + allow $1 var_lib_nfs_t:file { relabelfrom relabelto }; ') diff --git a/policy/modules/services/rpc.te b/policy/modules/services/rpc.te -index a3b9f86..eae7d14 100644 +index 8e1ab72..9ae080e 100644 --- a/policy/modules/services/rpc.te +++ b/policy/modules/services/rpc.te @@ -63,8 +63,9 @@ allow rpcd_t self:process { getcap setcap }; @@ -24073,7 +24282,7 @@ index a3b9f86..eae7d14 100644 # rpc.statd executes sm-notify can_exec(rpcd_t, rpcd_exec_t) -@@ -97,15 +98,26 @@ miscfiles_read_certs(rpcd_t) +@@ -97,15 +98,26 @@ miscfiles_read_generic_certs(rpcd_t) seutil_dontaudit_search_config(rpcd_t) @@ -24762,7 +24971,7 @@ index e30bb63..2a5981d 100644 + can_exec(smbd_t, samba_unconfined_script_exec_t) ') diff --git a/policy/modules/services/sasl.te b/policy/modules/services/sasl.te -index 41d60ad..8655cb0 100644 +index 22184ad..87810ec 100644 --- a/policy/modules/services/sasl.te +++ b/policy/modules/services/sasl.te @@ -42,13 +42,17 @@ allow saslauthd_t saslauthd_tmp_t:dir setattr; @@ -24876,7 +25085,7 @@ index 7e94c7c..4f7eb51 100644 + admin_pattern($1, mail_spool_t) +') diff --git a/policy/modules/services/sendmail.te b/policy/modules/services/sendmail.te -index 53dd7d0..668ce83 100644 +index 22dac1f..b6781d5 100644 --- a/policy/modules/services/sendmail.te +++ b/policy/modules/services/sendmail.te @@ -19,6 +19,9 @@ mta_sendmail_mailserver(sendmail_t) @@ -24904,7 +25113,7 @@ index 53dd7d0..668ce83 100644 auth_use_nsswitch(sendmail_t) -@@ -103,7 +108,7 @@ miscfiles_read_certs(sendmail_t) +@@ -103,7 +108,7 @@ miscfiles_read_generic_certs(sendmail_t) miscfiles_read_localization(sendmail_t) userdom_dontaudit_use_unpriv_user_fds(sendmail_t) @@ -25641,7 +25850,7 @@ index 078bcd7..dd706b0 100644 +/root/\.ssh(/.*)? gen_context(system_u:object_r:home_ssh_t,s0) +/root/\.shosts gen_context(system_u:object_r:home_ssh_t,s0) diff --git a/policy/modules/services/ssh.if b/policy/modules/services/ssh.if -index 5437ffb..8dad56a 100644 +index 22adaca..3061e83 100644 --- a/policy/modules/services/ssh.if +++ b/policy/modules/services/ssh.if @@ -36,6 +36,7 @@ template(`ssh_basic_client_template',` @@ -26259,10 +26468,19 @@ index aa0cc45..debff69 100644 + +iscsi_manage_semaphores(tgtd_t) diff --git a/policy/modules/services/tor.te b/policy/modules/services/tor.te -index 9fa94e4..81e8d3c 100644 +index 9fa94e4..0a0074c 100644 --- a/policy/modules/services/tor.te +++ b/policy/modules/services/tor.te -@@ -67,9 +67,10 @@ manage_sock_files_pattern(tor_t, tor_var_log_t, tor_var_log_t) +@@ -42,6 +42,8 @@ files_pid_file(tor_var_run_t) + # + + allow tor_t self:capability { setgid setuid sys_tty_config }; ++allow tor_t self:process signal; ++ + allow tor_t self:fifo_file rw_fifo_file_perms; + allow tor_t self:unix_stream_socket create_stream_socket_perms; + allow tor_t self:netlink_route_socket r_netlink_socket_perms; +@@ -67,9 +69,10 @@ manage_sock_files_pattern(tor_t, tor_var_log_t, tor_var_log_t) logging_log_filetrans(tor_t, tor_var_log_t, { sock_file file dir }) # pid file @@ -26274,7 +26492,7 @@ index 9fa94e4..81e8d3c 100644 kernel_read_system_state(tor_t) -@@ -88,6 +89,7 @@ corenet_tcp_connect_all_ports(tor_t) +@@ -88,6 +91,7 @@ corenet_tcp_connect_all_ports(tor_t) corenet_sendrecv_all_client_packets(tor_t) # ... especially including port 80 and other privileged ports corenet_tcp_connect_all_reserved_ports(tor_t) @@ -26282,7 +26500,7 @@ index 9fa94e4..81e8d3c 100644 # tor uses crypto and needs random dev_read_urand(tor_t) -@@ -100,6 +102,8 @@ files_read_usr_files(tor_t) +@@ -100,6 +104,8 @@ files_read_usr_files(tor_t) auth_use_nsswitch(tor_t) @@ -26751,7 +26969,7 @@ index 7c5d8d8..1a0701b 100644 +') + diff --git a/policy/modules/services/virt.te b/policy/modules/services/virt.te -index 3cce663..5a77c23 100644 +index 3eca020..f38e1ce 100644 --- a/policy/modules/services/virt.te +++ b/policy/modules/services/virt.te @@ -4,6 +4,7 @@ policy_module(virt, 1.4.0) @@ -27201,7 +27419,7 @@ index 3cce663..5a77c23 100644 +') + diff --git a/policy/modules/services/w3c.te b/policy/modules/services/w3c.te -index 2dec92e..c37d690 100644 +index 1174ad8..f4c4c1b 100644 --- a/policy/modules/services/w3c.te +++ b/policy/modules/services/w3c.te @@ -7,11 +7,18 @@ policy_module(w3c, 1.0.0) @@ -27224,7 +27442,7 @@ index 2dec92e..c37d690 100644 corenet_tcp_sendrecv_ftp_port(httpd_w3c_validator_script_t) corenet_tcp_connect_http_port(httpd_w3c_validator_script_t) @@ -22,3 +29,5 @@ corenet_tcp_sendrecv_http_cache_port(httpd_w3c_validator_script_t) - miscfiles_read_certs(httpd_w3c_validator_script_t) + miscfiles_read_generic_certs(httpd_w3c_validator_script_t) sysnet_dns_name_resolve(httpd_w3c_validator_script_t) + @@ -28010,7 +28228,7 @@ index da2601a..4bc9fff 100644 + manage_files_pattern($1, user_fonts_config_t, user_fonts_config_t) +') diff --git a/policy/modules/services/xserver.te b/policy/modules/services/xserver.te -index e226da4..9b9e013 100644 +index e226da4..5fbf38f 100644 --- a/policy/modules/services/xserver.te +++ b/policy/modules/services/xserver.te @@ -35,6 +35,13 @@ gen_tunable(allow_write_xshm, false) @@ -28451,7 +28669,7 @@ index e226da4..9b9e013 100644 dev_setattr_apm_bios_dev(xdm_t) dev_rw_dri(xdm_t) dev_rw_agp(xdm_t) -@@ -410,18 +560,22 @@ dev_setattr_xserver_misc_dev(xdm_t) +@@ -410,18 +560,23 @@ dev_setattr_xserver_misc_dev(xdm_t) dev_getattr_misc_dev(xdm_t) dev_setattr_misc_dev(xdm_t) dev_dontaudit_rw_misc(xdm_t) @@ -28474,10 +28692,11 @@ index e226da4..9b9e013 100644 # Do not audit denied probes of /proc. domain_dontaudit_read_all_domains_state(xdm_t) +domain_dontaudit_ptrace_all_domains(xdm_t) ++domain_dontaudit_signal_all_domains(xdm_t) files_read_etc_files(xdm_t) files_read_var_files(xdm_t) -@@ -432,9 +586,17 @@ files_list_mnt(xdm_t) +@@ -432,9 +587,17 @@ files_list_mnt(xdm_t) files_read_usr_files(xdm_t) # Poweroff wants to create the /poweroff file when run from xdm files_create_boot_flag(xdm_t) @@ -28495,7 +28714,7 @@ index e226da4..9b9e013 100644 storage_dontaudit_read_fixed_disk(xdm_t) storage_dontaudit_write_fixed_disk(xdm_t) -@@ -443,28 +605,36 @@ storage_dontaudit_raw_read_removable_device(xdm_t) +@@ -443,28 +606,36 @@ storage_dontaudit_raw_read_removable_device(xdm_t) storage_dontaudit_raw_write_removable_device(xdm_t) storage_dontaudit_setattr_removable_dev(xdm_t) storage_dontaudit_rw_scsi_generic(xdm_t) @@ -28534,7 +28753,7 @@ index e226da4..9b9e013 100644 userdom_dontaudit_use_unpriv_user_fds(xdm_t) userdom_create_all_users_keys(xdm_t) -@@ -473,6 +643,13 @@ userdom_read_user_home_content_files(xdm_t) +@@ -473,6 +644,13 @@ userdom_read_user_home_content_files(xdm_t) # Search /proc for any user domain processes. userdom_read_all_users_state(xdm_t) userdom_signal_all_users(xdm_t) @@ -28548,7 +28767,7 @@ index e226da4..9b9e013 100644 xserver_rw_session(xdm_t, xdm_tmpfs_t) xserver_unconfined(xdm_t) -@@ -504,11 +681,17 @@ tunable_policy(`xdm_sysadm_login',` +@@ -504,11 +682,17 @@ tunable_policy(`xdm_sysadm_login',` ') optional_policy(` @@ -28566,7 +28785,7 @@ index e226da4..9b9e013 100644 ') optional_policy(` -@@ -516,12 +699,51 @@ optional_policy(` +@@ -516,12 +700,51 @@ optional_policy(` ') optional_policy(` @@ -28618,7 +28837,7 @@ index e226da4..9b9e013 100644 hostname_exec(xdm_t) ') -@@ -539,20 +761,64 @@ optional_policy(` +@@ -539,20 +762,64 @@ optional_policy(` ') optional_policy(` @@ -28685,7 +28904,7 @@ index e226da4..9b9e013 100644 ifndef(`distro_redhat',` allow xdm_t self:process { execheap execmem }; -@@ -561,7 +827,6 @@ optional_policy(` +@@ -561,7 +828,6 @@ optional_policy(` ifdef(`distro_rhel4',` allow xdm_t self:process { execheap execmem }; ') @@ -28693,7 +28912,7 @@ index e226da4..9b9e013 100644 optional_policy(` userhelper_dontaudit_search_config(xdm_t) -@@ -572,6 +837,10 @@ optional_policy(` +@@ -572,6 +838,10 @@ optional_policy(` ') optional_policy(` @@ -28704,7 +28923,7 @@ index e226da4..9b9e013 100644 xfs_stream_connect(xdm_t) ') -@@ -596,7 +865,7 @@ allow xserver_t input_xevent_t:x_event send; +@@ -596,7 +866,7 @@ allow xserver_t input_xevent_t:x_event send; # execheap needed until the X module loader is fixed. # NVIDIA Needs execstack @@ -28713,7 +28932,7 @@ index e226da4..9b9e013 100644 dontaudit xserver_t self:capability chown; allow xserver_t self:process ~{ ptrace setcurrent setexec setfscreate setrlimit execmem execstack execheap }; allow xserver_t self:fd use; -@@ -610,6 +879,18 @@ allow xserver_t self:unix_dgram_socket { create_socket_perms sendto }; +@@ -610,6 +880,18 @@ allow xserver_t self:unix_dgram_socket { create_socket_perms sendto }; allow xserver_t self:unix_stream_socket { create_stream_socket_perms connectto }; allow xserver_t self:tcp_socket create_stream_socket_perms; allow xserver_t self:udp_socket create_socket_perms; @@ -28732,7 +28951,7 @@ index e226da4..9b9e013 100644 manage_dirs_pattern(xserver_t, xserver_tmp_t, xserver_tmp_t) manage_files_pattern(xserver_t, xserver_tmp_t, xserver_tmp_t) -@@ -629,12 +910,19 @@ manage_files_pattern(xserver_t, xkb_var_lib_t, xkb_var_lib_t) +@@ -629,12 +911,19 @@ manage_files_pattern(xserver_t, xkb_var_lib_t, xkb_var_lib_t) manage_lnk_files_pattern(xserver_t, xkb_var_lib_t, xkb_var_lib_t) files_search_var_lib(xserver_t) @@ -28754,7 +28973,7 @@ index e226da4..9b9e013 100644 kernel_read_system_state(xserver_t) kernel_read_device_sysctls(xserver_t) -@@ -642,6 +930,7 @@ kernel_read_modprobe_sysctls(xserver_t) +@@ -642,6 +931,7 @@ kernel_read_modprobe_sysctls(xserver_t) # Xorg wants to check if kernel is tainted kernel_read_kernel_sysctls(xserver_t) kernel_write_proc_files(xserver_t) @@ -28762,7 +28981,7 @@ index e226da4..9b9e013 100644 # Run helper programs in xserver_t. corecmd_exec_bin(xserver_t) -@@ -668,7 +957,6 @@ dev_rw_apm_bios(xserver_t) +@@ -668,7 +958,6 @@ dev_rw_apm_bios(xserver_t) dev_rw_agp(xserver_t) dev_rw_framebuffer(xserver_t) dev_manage_dri_dev(xserver_t) @@ -28770,7 +28989,7 @@ index e226da4..9b9e013 100644 dev_create_generic_dirs(xserver_t) dev_setattr_generic_dirs(xserver_t) # raw memory access is needed if not using the frame buffer -@@ -678,8 +966,13 @@ dev_wx_raw_memory(xserver_t) +@@ -678,8 +967,13 @@ dev_wx_raw_memory(xserver_t) dev_rw_xserver_misc(xserver_t) # read events - the synaptics touchpad driver reads raw events dev_rw_input_dev(xserver_t) @@ -28784,7 +29003,7 @@ index e226da4..9b9e013 100644 files_read_etc_files(xserver_t) files_read_etc_runtime_files(xserver_t) files_read_usr_files(xserver_t) -@@ -693,8 +986,13 @@ fs_getattr_xattr_fs(xserver_t) +@@ -693,8 +987,13 @@ fs_getattr_xattr_fs(xserver_t) fs_search_nfs(xserver_t) fs_search_auto_mountpoints(xserver_t) fs_search_ramfs(xserver_t) @@ -28798,7 +29017,7 @@ index e226da4..9b9e013 100644 selinux_validate_context(xserver_t) selinux_compute_access_vector(xserver_t) -@@ -716,11 +1014,14 @@ logging_send_audit_msgs(xserver_t) +@@ -716,11 +1015,14 @@ logging_send_audit_msgs(xserver_t) miscfiles_read_localization(xserver_t) miscfiles_read_fonts(xserver_t) @@ -28813,7 +29032,7 @@ index e226da4..9b9e013 100644 userdom_search_user_home_dirs(xserver_t) userdom_use_user_ttys(xserver_t) -@@ -773,12 +1074,28 @@ optional_policy(` +@@ -773,12 +1075,28 @@ optional_policy(` ') optional_policy(` @@ -28843,7 +29062,7 @@ index e226da4..9b9e013 100644 unconfined_domtrans(xserver_t) ') -@@ -787,6 +1104,10 @@ optional_policy(` +@@ -787,6 +1105,10 @@ optional_policy(` ') optional_policy(` @@ -28854,7 +29073,7 @@ index e226da4..9b9e013 100644 xfs_stream_connect(xserver_t) ') -@@ -802,10 +1123,10 @@ allow xserver_t xdm_t:shm rw_shm_perms; +@@ -802,10 +1124,10 @@ allow xserver_t xdm_t:shm rw_shm_perms; # NB we do NOT allow xserver_t xdm_var_lib_t:dir, only access to an open # handle of a file inside the dir!!! @@ -28867,7 +29086,7 @@ index e226da4..9b9e013 100644 # Label pid and temporary files with derived types. manage_files_pattern(xserver_t, xdm_tmp_t, xdm_tmp_t) -@@ -826,6 +1147,13 @@ init_use_fds(xserver_t) +@@ -826,6 +1148,13 @@ init_use_fds(xserver_t) # to read ROLE_home_t - examine this in more detail # (xauth?) userdom_read_user_home_content_files(xserver_t) @@ -28881,7 +29100,7 @@ index e226da4..9b9e013 100644 tunable_policy(`use_nfs_home_dirs',` fs_manage_nfs_dirs(xserver_t) -@@ -841,11 +1169,14 @@ tunable_policy(`use_samba_home_dirs',` +@@ -841,11 +1170,14 @@ tunable_policy(`use_samba_home_dirs',` optional_policy(` dbus_system_bus_client(xserver_t) @@ -28898,7 +29117,7 @@ index e226da4..9b9e013 100644 ') optional_policy(` -@@ -991,3 +1322,33 @@ allow xserver_unconfined_type { x_domain xserver_t }:x_keyboard *; +@@ -991,3 +1323,33 @@ allow xserver_unconfined_type { x_domain xserver_t }:x_keyboard *; allow xserver_unconfined_type xextension_type:x_extension *; allow xserver_unconfined_type { x_domain xserver_t }:x_resource *; allow xserver_unconfined_type xevent_type:{ x_event x_synthetic_event } *; @@ -29320,7 +29539,7 @@ index 1c4b1e7..2997dd7 100644 /var/lib/pam_ssh(/.*)? gen_context(system_u:object_r:var_auth_t,s0) diff --git a/policy/modules/system/authlogin.if b/policy/modules/system/authlogin.if -index 7fddc24..395f8f3 100644 +index bea0ade..bd3185e 100644 --- a/policy/modules/system/authlogin.if +++ b/policy/modules/system/authlogin.if @@ -57,6 +57,8 @@ interface(`auth_use_pam',` @@ -29504,7 +29723,7 @@ index 7fddc24..395f8f3 100644 optional_policy(` diff --git a/policy/modules/system/authlogin.te b/policy/modules/system/authlogin.te -index 7233a6d..bd9d529 100644 +index 54d122b..ee0fe55 100644 --- a/policy/modules/system/authlogin.te +++ b/policy/modules/system/authlogin.te @@ -8,6 +8,7 @@ policy_module(authlogin, 2.2.0) @@ -29878,7 +30097,7 @@ index 9775375..b338481 100644 # # /var diff --git a/policy/modules/system/init.if b/policy/modules/system/init.if -index f6aafe7..f28524b 100644 +index f6aafe7..447aaec 100644 --- a/policy/modules/system/init.if +++ b/policy/modules/system/init.if @@ -105,7 +105,11 @@ interface(`init_domain',` @@ -30143,7 +30362,33 @@ index f6aafe7..f28524b 100644 ## init scripts over dbus. ##
## -@@ -1637,7 +1754,7 @@ interface(`init_dontaudit_rw_utmp',` +@@ -1424,6 +1541,25 @@ interface(`init_getattr_script_status_files',` + + ######################################## + ## ++## Manage init script ++## status files. ++## ++## ++## ++## Domain allowed access. ++## ++## ++# ++interface(`init_manage_script_status_files',` ++ gen_require(` ++ type initrc_state_t; ++ ') ++ ++ manage_files_pattern($1, initrc_state_t, initrc_state_t) ++') ++ ++######################################## ++## + ## Do not audit attempts to read init script + ## status files. + ## +@@ -1637,7 +1773,7 @@ interface(`init_dontaudit_rw_utmp',` type initrc_var_run_t; ') @@ -30152,7 +30397,7 @@ index f6aafe7..f28524b 100644 ') ######################################## -@@ -1712,3 +1829,94 @@ interface(`init_udp_recvfrom_all_daemons',` +@@ -1712,3 +1848,94 @@ interface(`init_udp_recvfrom_all_daemons',` ') corenet_udp_recvfrom_labeled($1, daemon) ') @@ -30248,7 +30493,7 @@ index f6aafe7..f28524b 100644 + allow $1 init_t:unix_stream_socket rw_stream_socket_perms; +') diff --git a/policy/modules/system/init.te b/policy/modules/system/init.te -index abab4cf..d96bf27 100644 +index 698c11e..e0dc975 100644 --- a/policy/modules/system/init.te +++ b/policy/modules/system/init.te @@ -16,6 +16,27 @@ gen_require(` @@ -30569,7 +30814,7 @@ index abab4cf..d96bf27 100644 miscfiles_read_localization(initrc_t) # slapd needs to read cert files from its initscript --miscfiles_read_certs(initrc_t) +-miscfiles_read_generic_certs(initrc_t) +miscfiles_manage_cert_files(initrc_t) modutils_read_module_config(initrc_t) @@ -32162,10 +32407,18 @@ index 86ef2da..7f649d5 100644 ') diff --git a/policy/modules/system/miscfiles.fc b/policy/modules/system/miscfiles.fc -index 7711464..63c1b2f 100644 +index 7711464..1f0ccfd 100644 --- a/policy/modules/system/miscfiles.fc +++ b/policy/modules/system/miscfiles.fc -@@ -75,13 +75,11 @@ ifdef(`distro_redhat',` +@@ -11,6 +11,7 @@ ifdef(`distro_gentoo',` + /etc/avahi/etc/localtime -- gen_context(system_u:object_r:locale_t,s0) + /etc/localtime -- gen_context(system_u:object_r:locale_t,s0) + /etc/pki(/.*)? gen_context(system_u:object_r:cert_t,s0) ++/etc/httpd/alias/[^/]*\.db(\.[^/]*)* -- gen_context(system_u:object_r:cert_t,s0) + + ifdef(`distro_redhat',` + /etc/sysconfig/clock -- gen_context(system_u:object_r:locale_t,s0) +@@ -75,13 +76,11 @@ ifdef(`distro_redhat',` /var/cache/fonts(/.*)? gen_context(system_u:object_r:tetex_data_t,s0) /var/cache/man(/.*)? gen_context(system_u:object_r:man_t,s0) @@ -32182,78 +32435,10 @@ index 7711464..63c1b2f 100644 ifdef(`distro_debian',` /var/lib/msttcorefonts(/.*)? gen_context(system_u:object_r:fonts_t,s0) diff --git a/policy/modules/system/miscfiles.if b/policy/modules/system/miscfiles.if -index 17de283..4eeb1a5 100644 +index fe4e741..926ba65 100644 --- a/policy/modules/system/miscfiles.if +++ b/policy/modules/system/miscfiles.if -@@ -2,6 +2,50 @@ - - ######################################## - ## -+## Make the specified type usable as a cert file. -+## -+## -+##

-+## Make the specified type usable for cert files. -+## This will also make the type usable for files, making -+## calls to files_type() redundant. Failure to use this interface -+## for a temporary file may result in problems with -+## cert management tools. -+##

-+##

-+## Related interfaces: -+##

-+##
    -+##
  • files_type()
  • -+##
-+##

-+## Example: -+##

-+##

-+## type mycertfile_t; -+## cert_type(mycertfile_t) -+## allow mydomain_t mycertfile_t:file read_file_perms; -+## files_search_etc(mydomain_t) -+##

-+##
-+## -+## -+## Type to be used for files. -+## -+## -+## -+# -+interface(`miscfiles_cert_type',` -+ gen_require(` -+ attribute cert_type; -+ ') -+ -+ typeattribute $1 cert_type; -+ files_type($1) -+') -+ -+######################################## -+## - ## Read system SSL certificates. - ## - ## -@@ -13,12 +57,12 @@ - # - interface(`miscfiles_read_certs',` - gen_require(` -- type cert_t; -+ attribute cert_type; - ') - -- allow $1 cert_t:dir list_dir_perms; -- read_files_pattern($1, cert_t, cert_t) -- read_lnk_files_pattern($1, cert_t, cert_t) -+ allow $1 cert_type:dir list_dir_perms; -+ read_files_pattern($1, cert_type, cert_type) -+ read_lnk_files_pattern($1, cert_type, cert_type) - ') - - ######################################## -@@ -305,9 +349,6 @@ interface(`miscfiles_read_localization',` +@@ -414,9 +414,6 @@ interface(`miscfiles_read_localization',` allow $1 locale_t:dir list_dir_perms; read_files_pattern($1, locale_t, locale_t) read_lnk_files_pattern($1, locale_t, locale_t) @@ -32264,24 +32449,25 @@ index 17de283..4eeb1a5 100644 ######################################## diff --git a/policy/modules/system/miscfiles.te b/policy/modules/system/miscfiles.te -index 4ac5d56..eb75070 100644 +index c51f7f5..59c70bf 100644 --- a/policy/modules/system/miscfiles.te +++ b/policy/modules/system/miscfiles.te -@@ -4,12 +4,13 @@ policy_module(miscfiles, 1.8.0) +@@ -4,7 +4,6 @@ policy_module(miscfiles, 1.8.1) # # Declarations # -+attribute cert_type; +- + attribute cert_type; # - # cert_t is the type of files in the system certs directories. +@@ -12,6 +11,7 @@ attribute cert_type; # type cert_t; --files_type(cert_t) -+miscfiles_cert_type(cert_t) - + miscfiles_cert_type(cert_t) ++ # # fonts_t is the type of various font + # files in /usr diff --git a/policy/modules/system/modutils.if b/policy/modules/system/modutils.if index 9c0faab..def8d5a 100644 --- a/policy/modules/system/modutils.if @@ -32649,7 +32835,7 @@ index 8b5c196..3490497 100644 + role $2 types showmount_t; ') diff --git a/policy/modules/system/mount.te b/policy/modules/system/mount.te -index fca6947..a2f7102 100644 +index fca6947..1f8fee9 100644 --- a/policy/modules/system/mount.te +++ b/policy/modules/system/mount.te @@ -17,8 +17,15 @@ type mount_exec_t; @@ -32758,7 +32944,7 @@ index fca6947..a2f7102 100644 files_mount_all_file_type_fs(mount_t) files_unmount_all_file_type_fs(mount_t) # for when /etc/mtab loses its type -@@ -81,25 +127,32 @@ files_read_isid_type_files(mount_t) +@@ -81,25 +127,34 @@ files_read_isid_type_files(mount_t) files_read_usr_files(mount_t) files_list_mnt(mount_t) @@ -32779,6 +32965,8 @@ index fca6947..a2f7102 100644 +fs_read_fusefs_files(mount_t) +fs_manage_nfs_dirs(mount_t) +fs_read_nfs_symlinks(mount_t) ++fs_manage_cgroup_dirs(mount_t) ++fs_manage_cgroup_files(mount_t) mls_file_read_all_levels(mount_t) mls_file_write_all_levels(mount_t) @@ -32794,7 +32982,7 @@ index fca6947..a2f7102 100644 term_use_all_terms(mount_t) -@@ -108,6 +161,8 @@ auth_use_nsswitch(mount_t) +@@ -108,6 +163,8 @@ auth_use_nsswitch(mount_t) init_use_fds(mount_t) init_use_script_ptys(mount_t) init_dontaudit_getattr_initctl(mount_t) @@ -32803,7 +32991,7 @@ index fca6947..a2f7102 100644 logging_send_syslog_msg(mount_t) -@@ -118,6 +173,12 @@ sysnet_use_portmap(mount_t) +@@ -118,6 +175,12 @@ sysnet_use_portmap(mount_t) seutil_read_config(mount_t) userdom_use_all_users_fds(mount_t) @@ -32816,7 +33004,7 @@ index fca6947..a2f7102 100644 ifdef(`distro_redhat',` optional_policy(` -@@ -133,10 +194,17 @@ ifdef(`distro_ubuntu',` +@@ -133,10 +196,17 @@ ifdef(`distro_ubuntu',` ') ') @@ -32834,7 +33022,7 @@ index fca6947..a2f7102 100644 ') optional_policy(` -@@ -166,6 +234,8 @@ optional_policy(` +@@ -166,6 +236,8 @@ optional_policy(` fs_search_rpc(mount_t) rpc_stub(mount_t) @@ -32843,7 +33031,7 @@ index fca6947..a2f7102 100644 ') optional_policy(` -@@ -173,6 +243,25 @@ optional_policy(` +@@ -173,6 +245,25 @@ optional_policy(` ') optional_policy(` @@ -32869,7 +33057,7 @@ index fca6947..a2f7102 100644 ifdef(`hide_broken_symptoms',` # for a bug in the X server rhgb_dontaudit_rw_stream_sockets(mount_t) -@@ -180,6 +269,15 @@ optional_policy(` +@@ -180,6 +271,15 @@ optional_policy(` ') ') @@ -32885,7 +33073,7 @@ index fca6947..a2f7102 100644 # for kernel package installation optional_policy(` rpm_rw_pipes(mount_t) -@@ -187,6 +285,19 @@ optional_policy(` +@@ -187,6 +287,19 @@ optional_policy(` optional_policy(` samba_domtrans_smbmount(mount_t) @@ -32905,7 +33093,7 @@ index fca6947..a2f7102 100644 ') ######################################## -@@ -195,6 +306,42 @@ optional_policy(` +@@ -195,6 +308,42 @@ optional_policy(` # optional_policy(` @@ -32949,22 +33137,53 @@ index fca6947..a2f7102 100644 +sysnet_dns_name_resolve(showmount_t) + +userdom_use_user_terminals(showmount_t) +diff --git a/policy/modules/system/raid.fc b/policy/modules/system/raid.fc +index ed9c70d..42d3890 100644 +--- a/policy/modules/system/raid.fc ++++ b/policy/modules/system/raid.fc +@@ -1,4 +1,5 @@ +-/dev/.mdadm.map -- gen_context(system_u:object_r:mdadm_map_t,s0) ++/dev/.mdadm\.map -- gen_context(system_u:object_r:mdadm_var_run_t,s0) ++/dev/md(/.*)? gen_context(system_u:object_r:mdadm_var_run_t,s0) + + /sbin/mdadm -- gen_context(system_u:object_r:mdadm_exec_t,s0) + /sbin/mdmpd -- gen_context(system_u:object_r:mdadm_exec_t,s0) diff --git a/policy/modules/system/raid.te b/policy/modules/system/raid.te -index 09845c4..2fe5969 100644 +index 09845c4..6500830 100644 --- a/policy/modules/system/raid.te +++ b/policy/modules/system/raid.te -@@ -30,8 +30,9 @@ allow mdadm_t self:fifo_file rw_fifo_file_perms; - allow mdadm_t mdadm_map_t:file manage_file_perms; - dev_filetrans(mdadm_t, mdadm_map_t, file) +@@ -10,11 +10,9 @@ type mdadm_exec_t; + init_daemon_domain(mdadm_t, mdadm_exec_t) + role system_r types mdadm_t; +-type mdadm_map_t; +-files_type(mdadm_map_t) +- +-type mdadm_var_run_t; ++type mdadm_var_run_t alias mdadm_map_t; + files_pid_file(mdadm_var_run_t) ++dev_associate(mdadm_var_run_t) + + ######################################## + # +@@ -26,12 +24,11 @@ dontaudit mdadm_t self:capability sys_tty_config; + allow mdadm_t self:process { sigchld sigkill sigstop signull signal }; + allow mdadm_t self:fifo_file rw_fifo_file_perms; + +-# create .mdadm files in /dev +-allow mdadm_t mdadm_map_t:file manage_file_perms; +-dev_filetrans(mdadm_t, mdadm_map_t, file) +- +manage_dirs_pattern(mdadm_t, mdadm_var_run_t, mdadm_var_run_t) manage_files_pattern(mdadm_t, mdadm_var_run_t, mdadm_var_run_t) -files_pid_filetrans(mdadm_t, mdadm_var_run_t, file) ++manage_sock_files_pattern(mdadm_t, mdadm_var_run_t, mdadm_var_run_t) +files_pid_filetrans(mdadm_t, mdadm_var_run_t, { file dir }) ++dev_filetrans(mdadm_t, mdadm_var_run_t, { file dir sock_file }) kernel_read_system_state(mdadm_t) kernel_read_kernel_sysctls(mdadm_t) -@@ -52,13 +53,16 @@ dev_dontaudit_getattr_generic_blk_files(mdadm_t) +@@ -52,13 +49,16 @@ dev_dontaudit_getattr_generic_blk_files(mdadm_t) dev_read_realtime_clock(mdadm_t) # unfortunately needed for DMI decoding: dev_read_raw_memory(mdadm_t) @@ -35447,7 +35666,7 @@ index db75976..61db6da 100644 +HOME_DIR/\.pki(/.*)? gen_context(system_u:object_r:home_cert_t,s0) +HOME_DIR/\.gvfs(/.*)? <> diff --git a/policy/modules/system/userdomain.if b/policy/modules/system/userdomain.if -index 8b4f6d8..e1da594 100644 +index 2aa8928..c67c8e8 100644 --- a/policy/modules/system/userdomain.if +++ b/policy/modules/system/userdomain.if @@ -30,8 +30,9 @@ template(`userdom_base_user_template',` @@ -35461,7 +35680,7 @@ index 8b4f6d8..e1da594 100644 domain_type($1_t) corecmd_shell_entry_type($1_t) corecmd_bin_entry_type($1_t) -@@ -43,69 +44,92 @@ template(`userdom_base_user_template',` +@@ -43,69 +44,95 @@ template(`userdom_base_user_template',` term_user_pty($1_t, user_devpts_t) term_user_tty($1_t, user_tty_device_t) @@ -35592,20 +35811,21 @@ index 8b4f6d8..e1da594 100644 - libs_exec_ld_so($1_t) + init_stream_connect($1_usertype) - -- miscfiles_read_localization($1_t) -- miscfiles_read_certs($1_t) ++ + libs_exec_ld_so($1_usertype) + miscfiles_read_localization($1_t) + miscfiles_read_generic_certs($1_t) + - sysnet_read_config($1_t) -+ miscfiles_read_certs($1_usertype) ++ miscfiles_read_all_certs($1_usertype) + miscfiles_read_localization($1_usertype) + miscfiles_read_man_pages($1_usertype) + miscfiles_read_public_files($1_usertype) tunable_policy(`allow_execmem',` # Allow loading DSOs that require executable stack. -@@ -116,6 +140,16 @@ template(`userdom_base_user_template',` +@@ -116,6 +143,16 @@ template(`userdom_base_user_template',` # Allow making the stack executable via mprotect. allow $1_t self:process execstack; ') @@ -35622,7 +35842,7 @@ index 8b4f6d8..e1da594 100644 ') ####################################### -@@ -149,6 +183,8 @@ interface(`userdom_ro_home_role',` +@@ -149,6 +186,8 @@ interface(`userdom_ro_home_role',` type user_home_t, user_home_dir_t; ') @@ -35631,7 +35851,7 @@ index 8b4f6d8..e1da594 100644 ############################## # # Domain access to home dir -@@ -166,27 +202,6 @@ interface(`userdom_ro_home_role',` +@@ -166,27 +205,6 @@ interface(`userdom_ro_home_role',` read_sock_files_pattern($2, { user_home_t user_home_dir_t }, user_home_t) files_list_home($2) @@ -35659,7 +35879,7 @@ index 8b4f6d8..e1da594 100644 ') ####################################### -@@ -218,8 +233,11 @@ interface(`userdom_ro_home_role',` +@@ -218,8 +236,11 @@ interface(`userdom_ro_home_role',` interface(`userdom_manage_home_role',` gen_require(` type user_home_t, user_home_dir_t; @@ -35671,7 +35891,7 @@ index 8b4f6d8..e1da594 100644 ############################## # # Domain access to home dir -@@ -228,17 +246,21 @@ interface(`userdom_manage_home_role',` +@@ -228,17 +249,21 @@ interface(`userdom_manage_home_role',` type_member $2 user_home_dir_t:dir user_home_dir_t; # full control of the home directory @@ -35703,7 +35923,7 @@ index 8b4f6d8..e1da594 100644 filetrans_pattern($2, user_home_dir_t, user_home_t, { dir file lnk_file sock_file fifo_file }) files_list_home($2) -@@ -246,25 +268,23 @@ interface(`userdom_manage_home_role',` +@@ -246,25 +271,23 @@ interface(`userdom_manage_home_role',` allow $2 user_home_dir_t:dir { manage_dir_perms relabel_dir_perms }; tunable_policy(`use_nfs_home_dirs',` @@ -35733,7 +35953,7 @@ index 8b4f6d8..e1da594 100644 ') ') -@@ -289,6 +309,8 @@ interface(`userdom_manage_tmp_role',` +@@ -289,6 +312,8 @@ interface(`userdom_manage_tmp_role',` type user_tmp_t; ') @@ -35742,7 +35962,7 @@ index 8b4f6d8..e1da594 100644 files_poly_member_tmp($2, user_tmp_t) manage_dirs_pattern($2, user_tmp_t, user_tmp_t) -@@ -297,6 +319,45 @@ interface(`userdom_manage_tmp_role',` +@@ -297,6 +322,45 @@ interface(`userdom_manage_tmp_role',` manage_sock_files_pattern($2, user_tmp_t, user_tmp_t) manage_fifo_files_pattern($2, user_tmp_t, user_tmp_t) files_tmp_filetrans($2, user_tmp_t, { dir file lnk_file sock_file fifo_file }) @@ -35788,7 +36008,7 @@ index 8b4f6d8..e1da594 100644 ') ####################################### -@@ -316,6 +377,7 @@ interface(`userdom_exec_user_tmp_files',` +@@ -316,6 +380,7 @@ interface(`userdom_exec_user_tmp_files',` ') exec_files_pattern($1, user_tmp_t, user_tmp_t) @@ -35796,7 +36016,7 @@ index 8b4f6d8..e1da594 100644 files_search_tmp($1) ') -@@ -350,6 +412,8 @@ interface(`userdom_manage_tmpfs_role',` +@@ -350,6 +415,8 @@ interface(`userdom_manage_tmpfs_role',` type user_tmpfs_t; ') @@ -35805,7 +36025,7 @@ index 8b4f6d8..e1da594 100644 manage_dirs_pattern($2, user_tmpfs_t, user_tmpfs_t) manage_files_pattern($2, user_tmpfs_t, user_tmpfs_t) manage_lnk_files_pattern($2, user_tmpfs_t, user_tmpfs_t) -@@ -360,46 +424,41 @@ interface(`userdom_manage_tmpfs_role',` +@@ -360,46 +427,41 @@ interface(`userdom_manage_tmpfs_role',` ####################################### ## @@ -35874,7 +36094,7 @@ index 8b4f6d8..e1da594 100644 ') ####################################### -@@ -430,6 +489,7 @@ template(`userdom_xwindows_client_template',` +@@ -430,6 +492,7 @@ template(`userdom_xwindows_client_template',` dev_dontaudit_rw_dri($1_t) # GNOME checks for usb and other devices: dev_rw_usbfs($1_t) @@ -35882,7 +36102,7 @@ index 8b4f6d8..e1da594 100644 xserver_user_x_domain_template($1, $1_t, user_tmpfs_t) xserver_xsession_entry_type($1_t) -@@ -490,7 +550,7 @@ template(`userdom_common_user_template',` +@@ -490,7 +553,7 @@ template(`userdom_common_user_template',` attribute unpriv_userdomain; ') @@ -35891,7 +36111,7 @@ index 8b4f6d8..e1da594 100644 ############################## # -@@ -500,73 +560,78 @@ template(`userdom_common_user_template',` +@@ -500,73 +563,78 @@ template(`userdom_common_user_template',` # evolution and gnome-session try to create a netlink socket dontaudit $1_t self:netlink_socket { create ioctl read getattr write setattr append bind connect getopt setopt shutdown }; dontaudit $1_t self:netlink_route_socket { create ioctl read getattr write setattr append bind connect getopt setopt shutdown nlmsg_read nlmsg_write }; @@ -35912,27 +36132,27 @@ index 8b4f6d8..e1da594 100644 + kernel_get_sysvipc_info($1_usertype) # Find CDROM devices: - kernel_read_device_sysctls($1_t) -- -- corecmd_exec_bin($1_t) + kernel_read_device_sysctls($1_usertype) + kernel_request_load_module($1_usertype) -- corenet_udp_bind_generic_node($1_t) -- corenet_udp_bind_generic_port($1_t) +- corecmd_exec_bin($1_t) + corenet_udp_bind_generic_node($1_usertype) + corenet_udp_bind_generic_port($1_usertype) -- dev_read_rand($1_t) -- dev_write_sound($1_t) -- dev_read_sound($1_t) -- dev_read_sound_mixer($1_t) -- dev_write_sound_mixer($1_t) +- corenet_udp_bind_generic_node($1_t) +- corenet_udp_bind_generic_port($1_t) + dev_read_rand($1_usertype) + dev_write_sound($1_usertype) + dev_read_sound($1_usertype) + dev_read_sound_mixer($1_usertype) + dev_write_sound_mixer($1_usertype) +- dev_read_rand($1_t) +- dev_write_sound($1_t) +- dev_read_sound($1_t) +- dev_read_sound_mixer($1_t) +- dev_write_sound_mixer($1_t) +- - files_exec_etc_files($1_t) - files_search_locks($1_t) + files_exec_etc_files($1_usertype) @@ -36009,7 +36229,7 @@ index 8b4f6d8..e1da594 100644 ') tunable_policy(`user_ttyfile_stat',` -@@ -574,65 +639,108 @@ template(`userdom_common_user_template',` +@@ -574,65 +642,108 @@ template(`userdom_common_user_template',` ') optional_policy(` @@ -36021,19 +36241,19 @@ index 8b4f6d8..e1da594 100644 # Allow graphical boot to check battery lifespan - apm_stream_connect($1_t) + apm_stream_connect($1_usertype) ++ ') ++ ++ optional_policy(` ++ canna_stream_connect($1_usertype) ') optional_policy(` - canna_stream_connect($1_t) -+ canna_stream_connect($1_usertype) ++ chrome_role($1_r, $1_usertype) ') optional_policy(` - dbus_system_bus_client($1_t) -+ chrome_role($1_r, $1_usertype) -+ ') -+ -+ optional_policy(` + dbus_system_bus_client($1_usertype) + + allow $1_usertype $1_usertype:dbus send_msg; @@ -36060,47 +36280,47 @@ index 8b4f6d8..e1da594 100644 + devicekit_dbus_chat_power($1_usertype) + devicekit_dbus_chat_disk($1_usertype) + ') -+ -+ optional_policy(` -+ evolution_dbus_chat($1_usertype) -+ evolution_alarm_dbus_chat($1_usertype) -+ ') optional_policy(` - bluetooth_dbus_chat($1_t) -+ gnome_dbus_chat_gconfdefault($1_usertype) ++ evolution_dbus_chat($1_usertype) ++ evolution_alarm_dbus_chat($1_usertype) ') optional_policy(` - evolution_dbus_chat($1_t) - evolution_alarm_dbus_chat($1_t) -+ hal_dbus_chat($1_usertype) ++ gnome_dbus_chat_gconfdefault($1_usertype) ') optional_policy(` - cups_dbus_chat_config($1_t) -+ modemmanager_dbus_chat($1_usertype) ++ hal_dbus_chat($1_usertype) ') optional_policy(` - hal_dbus_chat($1_t) -+ networkmanager_dbus_chat($1_usertype) -+ networkmanager_read_lib_files($1_usertype) ++ modemmanager_dbus_chat($1_usertype) ') optional_policy(` - networkmanager_dbus_chat($1_t) -+ vpn_dbus_chat($1_usertype) ++ networkmanager_dbus_chat($1_usertype) ++ networkmanager_read_lib_files($1_usertype) ') ++ ++ optional_policy(` ++ vpn_dbus_chat($1_usertype) ++ ') ++ ') ++ ++ optional_policy(` ++ git_session_role($1_r, $1_usertype) ') optional_policy(` - inetd_use_fds($1_t) - inetd_rw_tcp_sockets($1_t) -+ git_session_role($1_r, $1_usertype) -+ ') -+ -+ optional_policy(` + inetd_use_fds($1_usertype) + inetd_rw_tcp_sockets($1_usertype) ') @@ -36136,7 +36356,7 @@ index 8b4f6d8..e1da594 100644 ') optional_policy(` -@@ -643,41 +751,50 @@ template(`userdom_common_user_template',` +@@ -643,41 +754,50 @@ template(`userdom_common_user_template',` optional_policy(` # to allow monitoring of pcmcia status @@ -36163,33 +36383,33 @@ index 8b4f6d8..e1da594 100644 optional_policy(` - resmgr_stream_connect($1_t) + resmgr_stream_connect($1_usertype) ++ ') ++ ++ optional_policy(` ++ rpc_dontaudit_getattr_exports($1_usertype) ++ rpc_manage_nfs_rw_content($1_usertype) ') optional_policy(` - rpc_dontaudit_getattr_exports($1_t) - rpc_manage_nfs_rw_content($1_t) -+ rpc_dontaudit_getattr_exports($1_usertype) -+ rpc_manage_nfs_rw_content($1_usertype) ++ rpcbind_stream_connect($1_usertype) ') optional_policy(` - samba_stream_connect_winbind($1_t) -+ rpcbind_stream_connect($1_usertype) ++ samba_stream_connect_winbind($1_usertype) ') optional_policy(` - slrnpull_search_spool($1_t) -+ samba_stream_connect_winbind($1_usertype) ++ sandbox_transition($1_usertype, $1_r) ') optional_policy(` - usernetctl_run($1_t,$1_r) -+ sandbox_transition($1_usertype, $1_r) - ') -+ -+ optional_policy(` + seunshare_role_template($1, $1_r, $1_t) -+ ') + ') + + optional_policy(` + slrnpull_search_spool($1_usertype) @@ -36198,23 +36418,23 @@ index 8b4f6d8..e1da594 100644 ') ####################################### -@@ -705,13 +822,26 @@ template(`userdom_login_user_template', ` +@@ -705,13 +825,26 @@ template(`userdom_login_user_template', ` userdom_base_user_template($1) - userdom_manage_home_role($1_r, $1_t) + userdom_manage_home_role($1_r, $1_usertype) -+ -+ userdom_manage_tmp_role($1_r, $1_usertype) -+ userdom_manage_tmpfs_role($1_r, $1_usertype) - userdom_manage_tmp_role($1_r, $1_t) - userdom_manage_tmpfs_role($1_r, $1_t) -+ ifelse(`$1',`unconfined',`',` -+ gen_tunable(allow_$1_exec_content, true) ++ userdom_manage_tmp_role($1_r, $1_usertype) ++ userdom_manage_tmpfs_role($1_r, $1_usertype) - userdom_exec_user_tmp_files($1_t) - userdom_exec_user_home_content_files($1_t) ++ ifelse(`$1',`unconfined',`',` ++ gen_tunable(allow_$1_exec_content, true) ++ + tunable_policy(`allow_$1_exec_content',` + userdom_exec_user_tmp_files($1_usertype) + userdom_exec_user_home_content_files($1_usertype) @@ -36230,7 +36450,7 @@ index 8b4f6d8..e1da594 100644 userdom_change_password_template($1) -@@ -729,72 +859,74 @@ template(`userdom_login_user_template', ` +@@ -729,72 +862,74 @@ template(`userdom_login_user_template', ` allow $1_t self:context contains; @@ -36298,49 +36518,49 @@ index 8b4f6d8..e1da594 100644 - miscfiles_exec_tetex_data($1_t) + miscfiles_read_tetex_data($1_usertype) + miscfiles_exec_tetex_data($1_usertype) -+ -+ seutil_read_config($1_usertype) - seutil_read_config($1_t) -+ optional_policy(` -+ cups_read_config($1_usertype) -+ cups_stream_connect($1_usertype) -+ cups_stream_connect_ptal($1_usertype) -+ ') ++ seutil_read_config($1_usertype) optional_policy(` - cups_read_config($1_t) - cups_stream_connect($1_t) - cups_stream_connect_ptal($1_t) -+ kerberos_use($1_usertype) -+ kerberos_connect_524($1_usertype) ++ cups_read_config($1_usertype) ++ cups_stream_connect($1_usertype) ++ cups_stream_connect_ptal($1_usertype) ') optional_policy(` - kerberos_use($1_t) -+ mta_dontaudit_read_spool_symlinks($1_usertype) ++ kerberos_use($1_usertype) ++ kerberos_connect_524($1_usertype) ') optional_policy(` - mta_dontaudit_read_spool_symlinks($1_t) -+ quota_dontaudit_getattr_db($1_usertype) ++ mta_dontaudit_read_spool_symlinks($1_usertype) ') optional_policy(` - quota_dontaudit_getattr_db($1_t) -+ rpm_read_db($1_usertype) -+ rpm_dontaudit_manage_db($1_usertype) -+ rpm_read_cache($1_usertype) ++ quota_dontaudit_getattr_db($1_usertype) ') optional_policy(` - rpm_read_db($1_t) - rpm_dontaudit_manage_db($1_t) ++ rpm_read_db($1_usertype) ++ rpm_dontaudit_manage_db($1_usertype) ++ rpm_read_cache($1_usertype) ++ ') ++ ++ optional_policy(` + oddjob_run_mkhomedir($1_t, $1_r) ') ') -@@ -826,6 +958,9 @@ template(`userdom_restricted_user_template',` +@@ -826,6 +961,9 @@ template(`userdom_restricted_user_template',` typeattribute $1_t unpriv_userdomain; domain_interactive_fd($1_t) @@ -36350,7 +36570,7 @@ index 8b4f6d8..e1da594 100644 ############################## # # Local policy -@@ -867,45 +1002,103 @@ template(`userdom_restricted_xwindows_user_template',` +@@ -867,45 +1005,103 @@ template(`userdom_restricted_xwindows_user_template',` # auth_role($1_r, $1_t) @@ -36465,7 +36685,7 @@ index 8b4f6d8..e1da594 100644 ') ') -@@ -940,7 +1133,7 @@ template(`userdom_unpriv_user_template', ` +@@ -940,7 +1136,7 @@ template(`userdom_unpriv_user_template', ` # # Inherit rules for ordinary users. @@ -36474,7 +36694,7 @@ index 8b4f6d8..e1da594 100644 userdom_common_user_template($1) ############################## -@@ -949,54 +1142,77 @@ template(`userdom_unpriv_user_template', ` +@@ -949,54 +1145,77 @@ template(`userdom_unpriv_user_template', ` # # port access is audited even if dac would not have allowed it, so dontaudit it here @@ -36582,7 +36802,7 @@ index 8b4f6d8..e1da594 100644 ') ') -@@ -1032,7 +1248,7 @@ template(`userdom_unpriv_user_template', ` +@@ -1032,7 +1251,7 @@ template(`userdom_unpriv_user_template', ` template(`userdom_admin_user_template',` gen_require(` attribute admindomain; @@ -36591,7 +36811,7 @@ index 8b4f6d8..e1da594 100644 ') ############################## -@@ -1067,6 +1283,9 @@ template(`userdom_admin_user_template',` +@@ -1067,6 +1286,9 @@ template(`userdom_admin_user_template',` # Skip authentication when pam_rootok is specified. allow $1_t self:passwd rootok; @@ -36601,7 +36821,7 @@ index 8b4f6d8..e1da594 100644 kernel_read_software_raid_state($1_t) kernel_getattr_core_if($1_t) kernel_getattr_message_if($1_t) -@@ -1081,6 +1300,7 @@ template(`userdom_admin_user_template',` +@@ -1081,6 +1303,7 @@ template(`userdom_admin_user_template',` kernel_sigstop_unlabeled($1_t) kernel_signull_unlabeled($1_t) kernel_sigchld_unlabeled($1_t) @@ -36609,7 +36829,7 @@ index 8b4f6d8..e1da594 100644 corenet_tcp_bind_generic_port($1_t) # allow setting up tunnels -@@ -1112,10 +1332,13 @@ template(`userdom_admin_user_template',` +@@ -1112,10 +1335,13 @@ template(`userdom_admin_user_template',` domain_sigchld_all_domains($1_t) # for lsof domain_getattr_all_sockets($1_t) @@ -36623,7 +36843,7 @@ index 8b4f6d8..e1da594 100644 fs_set_all_quotas($1_t) fs_exec_noxattr($1_t) -@@ -1135,6 +1358,7 @@ template(`userdom_admin_user_template',` +@@ -1135,6 +1361,7 @@ template(`userdom_admin_user_template',` logging_send_syslog_msg($1_t) modutils_domtrans_insmod($1_t) @@ -36631,7 +36851,7 @@ index 8b4f6d8..e1da594 100644 # The following rule is temporary until such time that a complete # policy management infrastructure is in place so that an administrator -@@ -1203,6 +1427,8 @@ template(`userdom_security_admin_template',` +@@ -1203,6 +1430,8 @@ template(`userdom_security_admin_template',` dev_relabel_all_dev_nodes($1) files_create_boot_flag($1) @@ -36640,7 +36860,7 @@ index 8b4f6d8..e1da594 100644 # Necessary for managing /boot/efi fs_manage_dos_files($1) -@@ -1230,6 +1456,7 @@ template(`userdom_security_admin_template',` +@@ -1230,6 +1459,7 @@ template(`userdom_security_admin_template',` seutil_run_checkpolicy($1,$2) seutil_run_loadpolicy($1,$2) seutil_run_semanage($1,$2) @@ -36648,7 +36868,7 @@ index 8b4f6d8..e1da594 100644 seutil_run_setfiles($1, $2) optional_policy(` -@@ -1268,12 +1495,15 @@ template(`userdom_security_admin_template',` +@@ -1268,12 +1498,15 @@ template(`userdom_security_admin_template',` interface(`userdom_user_home_content',` gen_require(` type user_home_t; @@ -36665,7 +36885,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -1384,6 +1614,7 @@ interface(`userdom_search_user_home_dirs',` +@@ -1384,6 +1617,7 @@ interface(`userdom_search_user_home_dirs',` ') allow $1 user_home_dir_t:dir search_dir_perms; @@ -36673,7 +36893,7 @@ index 8b4f6d8..e1da594 100644 files_search_home($1) ') -@@ -1430,6 +1661,14 @@ interface(`userdom_list_user_home_dirs',` +@@ -1430,6 +1664,14 @@ interface(`userdom_list_user_home_dirs',` allow $1 user_home_dir_t:dir list_dir_perms; files_search_home($1) @@ -36688,7 +36908,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -1445,9 +1684,11 @@ interface(`userdom_list_user_home_dirs',` +@@ -1445,9 +1687,11 @@ interface(`userdom_list_user_home_dirs',` interface(`userdom_dontaudit_list_user_home_dirs',` gen_require(` type user_home_dir_t; @@ -36700,7 +36920,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -1504,6 +1745,42 @@ interface(`userdom_relabelto_user_home_dirs',` +@@ -1504,6 +1748,42 @@ interface(`userdom_relabelto_user_home_dirs',` allow $1 user_home_dir_t:dir relabelto; ') @@ -36743,7 +36963,7 @@ index 8b4f6d8..e1da594 100644 ######################################## ## ## Create directories in the home dir root with -@@ -1578,6 +1855,8 @@ interface(`userdom_dontaudit_search_user_home_content',` +@@ -1578,6 +1858,8 @@ interface(`userdom_dontaudit_search_user_home_content',` ') dontaudit $1 user_home_t:dir search_dir_perms; @@ -36752,7 +36972,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -1592,10 +1871,12 @@ interface(`userdom_dontaudit_search_user_home_content',` +@@ -1592,10 +1874,12 @@ interface(`userdom_dontaudit_search_user_home_content',` # interface(`userdom_list_user_home_content',` gen_require(` @@ -36767,7 +36987,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -1638,6 +1919,25 @@ interface(`userdom_delete_user_home_content_dirs',` +@@ -1638,6 +1922,25 @@ interface(`userdom_delete_user_home_content_dirs',` ######################################## ## @@ -36793,7 +37013,7 @@ index 8b4f6d8..e1da594 100644 ## Do not audit attempts to set the ## attributes of user home files. ## -@@ -1689,13 +1989,14 @@ interface(`userdom_read_user_home_content_files',` +@@ -1689,13 +1992,33 @@ interface(`userdom_read_user_home_content_files',` type user_home_dir_t, user_home_t; ') @@ -36806,29 +37026,6 @@ index 8b4f6d8..e1da594 100644 ## -## Do not audit attempts to read user home files. +## Do not audit attempts to getattr user home files. - ## - ## - ## -@@ -1703,13 +2004,35 @@ interface(`userdom_read_user_home_content_files',` - ## - ## - # --interface(`userdom_dontaudit_read_user_home_content_files',` -+interface(`userdom_dontaudit_getattr_user_home_content',` - gen_require(` -- type user_home_t; -+ attribute user_home_type; - ') - -- dontaudit $1 user_home_t:dir list_dir_perms; -- dontaudit $1 user_home_t:file read_file_perms; -+ dontaudit $1 user_home_type:dir getattr; -+ dontaudit $1 user_home_type:file getattr; -+') -+ -+######################################## -+## -+## Do not audit attempts to read user home files. +## +## +## @@ -36836,12 +37033,32 @@ index 8b4f6d8..e1da594 100644 +## +## +# -+interface(`userdom_dontaudit_read_user_home_content_files',` ++interface(`userdom_dontaudit_getattr_user_home_content',` + gen_require(` + attribute user_home_type; -+ type user_home_dir_t; + ') + ++ dontaudit $1 user_home_type:dir getattr; ++ dontaudit $1 user_home_type:file getattr; ++') ++ ++######################################## ++## ++## Do not audit attempts to read user home files. + ## + ## + ## +@@ -1705,11 +2028,14 @@ interface(`userdom_read_user_home_content_files',` + # + interface(`userdom_dontaudit_read_user_home_content_files',` + gen_require(` +- type user_home_t; ++ attribute user_home_type; ++ type user_home_dir_t; + ') + +- dontaudit $1 user_home_t:dir list_dir_perms; +- dontaudit $1 user_home_t:file read_file_perms; + dontaudit $1 user_home_dir_t:dir list_dir_perms; + dontaudit $1 user_home_type:dir list_dir_perms; + dontaudit $1 user_home_type:file read_file_perms; @@ -36849,7 +37066,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -1799,8 +2122,7 @@ interface(`userdom_read_user_home_content_symlinks',` +@@ -1799,8 +2125,7 @@ interface(`userdom_read_user_home_content_symlinks',` type user_home_dir_t, user_home_t; ') @@ -36859,7 +37076,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -1816,20 +2138,14 @@ interface(`userdom_read_user_home_content_symlinks',` +@@ -1816,21 +2141,15 @@ interface(`userdom_read_user_home_content_symlinks',` # interface(`userdom_exec_user_home_content_files',` gen_require(` @@ -36873,18 +37090,19 @@ index 8b4f6d8..e1da594 100644 - - tunable_policy(`use_nfs_home_dirs',` - fs_exec_nfs_files($1) -- ') -- -- tunable_policy(`use_samba_home_dirs',` -- fs_exec_cifs_files($1) + exec_files_pattern($1, { user_home_dir_t user_home_type }, user_home_type) + dontaudit $1 user_home_type:sock_file execute; ') --') +- tunable_policy(`use_samba_home_dirs',` +- fs_exec_cifs_files($1) +- ') +-') +- ######################################## ## -@@ -2171,7 +2487,7 @@ interface(`userdom_dontaudit_read_user_tmp_files',` + ## Do not audit attempts to execute user home files. +@@ -2171,7 +2490,7 @@ interface(`userdom_dontaudit_read_user_tmp_files',` type user_tmp_t; ') @@ -36893,7 +37111,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -2424,13 +2740,14 @@ interface(`userdom_read_user_tmpfs_files',` +@@ -2424,13 +2743,14 @@ interface(`userdom_read_user_tmpfs_files',` ') read_files_pattern($1, user_tmpfs_t, user_tmpfs_t) @@ -36909,7 +37127,7 @@ index 8b4f6d8..e1da594 100644 ## ## ## -@@ -2451,26 +2768,6 @@ interface(`userdom_rw_user_tmpfs_files',` +@@ -2451,26 +2771,6 @@ interface(`userdom_rw_user_tmpfs_files',` ######################################## ## @@ -36936,7 +37154,7 @@ index 8b4f6d8..e1da594 100644 ## Get the attributes of a user domain tty. ## ## -@@ -2804,7 +3101,7 @@ interface(`userdom_entry_spec_domtrans_unpriv_users',` +@@ -2804,7 +3104,7 @@ interface(`userdom_entry_spec_domtrans_unpriv_users',` domain_entry_file_spec_domtrans($1, unpriv_userdomain) allow unpriv_userdomain $1:fd use; @@ -36945,7 +37163,7 @@ index 8b4f6d8..e1da594 100644 allow unpriv_userdomain $1:process sigchld; ') -@@ -2820,11 +3117,13 @@ interface(`userdom_entry_spec_domtrans_unpriv_users',` +@@ -2820,11 +3120,13 @@ interface(`userdom_entry_spec_domtrans_unpriv_users',` # interface(`userdom_search_user_home_content',` gen_require(` @@ -36961,7 +37179,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -2906,7 +3205,7 @@ interface(`userdom_dontaudit_use_user_ptys',` +@@ -2906,7 +3208,7 @@ interface(`userdom_dontaudit_use_user_ptys',` type user_devpts_t; ') @@ -36970,7 +37188,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -2961,7 +3260,45 @@ interface(`userdom_write_user_tmp_files',` +@@ -2961,7 +3263,45 @@ interface(`userdom_write_user_tmp_files',` type user_tmp_t; ') @@ -37017,7 +37235,7 @@ index 8b4f6d8..e1da594 100644 ') ######################################## -@@ -2998,6 +3335,7 @@ interface(`userdom_read_all_users_state',` +@@ -2998,6 +3338,7 @@ interface(`userdom_read_all_users_state',` ') read_files_pattern($1, userdomain, userdomain) @@ -37025,7 +37243,7 @@ index 8b4f6d8..e1da594 100644 kernel_search_proc($1) ') -@@ -3128,3 +3466,854 @@ interface(`userdom_dbus_send_all_users',` +@@ -3128,3 +3469,854 @@ interface(`userdom_dbus_send_all_users',` allow $1 userdomain:dbus send_msg; ') @@ -38018,7 +38236,7 @@ index 77d41b6..4af4e6b 100644 ') diff --git a/policy/modules/system/xen.te b/policy/modules/system/xen.te -index f661f5a..ff472d0 100644 +index f661f5a..600d43f 100644 --- a/policy/modules/system/xen.te +++ b/policy/modules/system/xen.te @@ -4,6 +4,7 @@ policy_module(xen, 1.10.0) @@ -38049,7 +38267,33 @@ index f661f5a..ff472d0 100644 ####################################### # # evtchnd local policy -@@ -317,9 +314,10 @@ manage_dirs_pattern(xenstored_t, xenstored_tmp_t, xenstored_tmp_t) +@@ -113,7 +110,7 @@ files_pid_filetrans(evtchnd_t, evtchnd_var_run_t, { file sock_file dir }) + # xend local policy + # + +-allow xend_t self:capability { mknod dac_override ipc_lock net_admin setuid sys_nice sys_ptrace sys_tty_config net_raw }; ++allow xend_t self:capability { mknod dac_override ipc_lock net_admin setuid sys_admin sys_nice sys_ptrace sys_tty_config net_raw }; + dontaudit xend_t self:capability { sys_ptrace }; + allow xend_t self:process { signal sigkill }; + dontaudit xend_t self:process ptrace; +@@ -228,6 +225,7 @@ logging_send_syslog_msg(xend_t) + lvm_domtrans(xend_t) + + miscfiles_read_localization(xend_t) ++miscfiles_read_hwdata(xend_t) + + mount_domtrans(xend_t) + +@@ -245,6 +243,8 @@ xen_stream_connect_xenstore(xend_t) + + netutils_domtrans(xend_t) + ++virt_read_config(xend_t) ++ + optional_policy(` + brctl_domtrans(xend_t) + ') +@@ -317,9 +317,10 @@ manage_dirs_pattern(xenstored_t, xenstored_tmp_t, xenstored_tmp_t) files_tmp_filetrans(xenstored_t, xenstored_tmp_t, { file dir }) # pid file @@ -38061,7 +38305,7 @@ index f661f5a..ff472d0 100644 # log files manage_dirs_pattern(xenstored_t, xenstored_var_log_t, xenstored_var_log_t) -@@ -346,6 +344,7 @@ dev_read_sysfs(xenstored_t) +@@ -346,6 +347,7 @@ dev_read_sysfs(xenstored_t) files_read_usr_files(xenstored_t) @@ -38069,7 +38313,7 @@ index f661f5a..ff472d0 100644 fs_manage_xenfs_files(xenstored_t) storage_raw_read_fixed_disk(xenstored_t) -@@ -353,6 +352,7 @@ storage_raw_write_fixed_disk(xenstored_t) +@@ -353,6 +355,7 @@ storage_raw_write_fixed_disk(xenstored_t) storage_raw_read_removable_device(xenstored_t) term_use_generic_ptys(xenstored_t) @@ -38077,7 +38321,7 @@ index f661f5a..ff472d0 100644 init_use_fds(xenstored_t) init_use_script_ptys(xenstored_t) -@@ -365,98 +365,9 @@ xen_append_log(xenstored_t) +@@ -365,98 +368,9 @@ xen_append_log(xenstored_t) ######################################## # @@ -38176,7 +38420,7 @@ index f661f5a..ff472d0 100644 #Should have a boolean wrapping these fs_list_auto_mountpoints(xend_t) files_search_mnt(xend_t) -@@ -469,8 +380,4 @@ optional_policy(` +@@ -469,8 +383,4 @@ optional_policy(` fs_manage_nfs_files(xend_t) fs_read_nfs_symlinks(xend_t) ') diff --git a/selinux-policy.spec b/selinux-policy.spec index 8974d7b..4954b17 100644 --- a/selinux-policy.spec +++ b/selinux-policy.spec @@ -19,8 +19,8 @@ %define CHECKPOLICYVER 2.0.21-1 Summary: SELinux policy configuration Name: selinux-policy -Version: 3.9.3 -Release: 3%{?dist} +Version: 3.9.4 +Release: 1%{?dist} License: GPLv2+ Group: System Environment/Base Source: serefpolicy-%{version}.tgz @@ -469,6 +469,12 @@ exit 0 %endif %changelog +* Thu Sep 8 2010 Dan Walsh 3.9.4-1 +- Update to upstream + +* Thu Sep 8 2010 Dan Walsh 3.9.3-4 +- Allow mdadm_t to create files and sock files in /dev/md/ + * Thu Sep 8 2010 Dan Walsh 3.9.3-3 - Add policy for ajaxterm diff --git a/sources b/sources index 3c4a5ef..11bf11d 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -2330fe4b7094df0e0a453856db12e3a4 serefpolicy-3.9.3.tgz +c610a100e8448f4fdc2559d1e509494c serefpolicy-3.9.4.tgz