diff --git a/refpolicy/policy/modules/admin/logrotate.te b/refpolicy/policy/modules/admin/logrotate.te
index f800cd1a..31eb7b21 100644
--- a/refpolicy/policy/modules/admin/logrotate.te
+++ b/refpolicy/policy/modules/admin/logrotate.te
@@ -1,5 +1,5 @@
-policy_module(logrotate,1.0)
+policy_module(logrotate,1.0.1)
########################################
#
@@ -148,6 +148,10 @@ optional_policy(`consoletype',`
')
+optional_policy(`cups',`
+ cups_domtrans(logrotate_t)
+')
+
optional_policy(`hostname',`
hostname_exec(logrotate_t)
')
diff --git a/refpolicy/policy/modules/admin/rpm.if b/refpolicy/policy/modules/admin/rpm.if
index 75d25113..e8550e0a 100644
--- a/refpolicy/policy/modules/admin/rpm.if
+++ b/refpolicy/policy/modules/admin/rpm.if
@@ -151,6 +151,7 @@ interface(`rpm_read_db',`
type rpm_var_lib_t;
')
+ files_search_var_lib($1)
allow $1 rpm_var_lib_t:dir r_dir_perms;
allow $1 rpm_var_lib_t:file { getattr read };
allow $1 rpm_var_lib_t:lnk_file r_file_perms;
@@ -169,8 +170,8 @@ interface(`rpm_manage_db',`
type rpm_var_lib_t;
')
+ files_search_var_lib($1)
allow $1 rpm_var_lib_t:dir rw_dir_perms;
allow $1 rpm_var_lib_t:file { getattr create read write append unlink };
allow $1 rpm_var_lib_t:lnk_file { getattr read write unlink };
')
-
diff --git a/refpolicy/policy/modules/admin/updfstab.if b/refpolicy/policy/modules/admin/updfstab.if
index 753454f4..54748338 100644
--- a/refpolicy/policy/modules/admin/updfstab.if
+++ b/refpolicy/policy/modules/admin/updfstab.if
@@ -22,3 +22,22 @@ interface(`updfstab_domtrans',`
allow updfstab_t $1:fifo_file rw_file_perms;
allow updfstab_t $1:process sigchld;
')
+
+########################################
+##
+## Send and receive messages from
+## updfstab over dbus.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`updfstab_dbus_chat',`
+ gen_require(`
+ type updfstab_t;
+ class dbus send_msg;
+ ')
+
+ allow $1 updfstab_t:dbus send_msg;
+ allow updfstab_t $1:dbus send_msg;
+')
diff --git a/refpolicy/policy/modules/admin/updfstab.te b/refpolicy/policy/modules/admin/updfstab.te
index bf83e257..60a1468b 100644
--- a/refpolicy/policy/modules/admin/updfstab.te
+++ b/refpolicy/policy/modules/admin/updfstab.te
@@ -1,5 +1,5 @@
-policy_module(updfstab,1.0.1)
+policy_module(updfstab,1.0.2)
########################################
#
@@ -100,6 +100,7 @@ optional_policy(`dbus',`
optional_policy(`hal',`
hal_stream_connect(updfstab_t)
+ hal_dbus_chat(updfstab_t)
')
optional_policy(`modutils',`
@@ -123,8 +124,3 @@ optional_policy(`udev',`
ifdef(`TODO',`
allow updfstab_t tmpfs_t:dir getattr;
')
-
-optional_policy(`dbus',`
- allow initrc_t updfstab_t:dbus send_msg;
- allow updfstab_t initrc_t:dbus send_msg;
-')
diff --git a/refpolicy/policy/modules/kernel/devices.if b/refpolicy/policy/modules/kernel/devices.if
index 4a7ce1bd..0ae11653 100644
--- a/refpolicy/policy/modules/kernel/devices.if
+++ b/refpolicy/policy/modules/kernel/devices.if
@@ -824,6 +824,44 @@ interface(`dev_dontaudit_rw_cardmgr',`
dontaudit $1 cardmgr_dev_t:chr_file { read write };
')
+########################################
+##
+## Create, read, write, and delete
+## the PCMCIA card manager device.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`dev_manage_cardmgr',`
+ gen_require(`
+ type device_t, cardmgr_dev_t;
+ ')
+
+ allow $1 device_t:dir rw_dir_perms;
+ allow $1 cardmgr_dev_t:{ chr_file blk_file } manage_file_perms;
+')
+
+########################################
+##
+## Create, read, write, and delete
+## the PCMCIA card manager device
+## with the correct type.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`dev_create_cardmgr',`
+ gen_require(`
+ type device_t, cardmgr_dev_t;
+ ')
+
+ allow $1 device_t:dir rw_dir_perms;
+ allow $1 cardmgr_dev_t:{ chr_file blk_file } manage_file_perms;
+ type_transition $1 device_t:{ chr_file blk_file } cardmgr_dev_t;
+')
+
########################################
##
## Get the attributes of the CPU
diff --git a/refpolicy/policy/modules/kernel/filesystem.if b/refpolicy/policy/modules/kernel/filesystem.if
index 0725f408..c067a6e6 100644
--- a/refpolicy/policy/modules/kernel/filesystem.if
+++ b/refpolicy/policy/modules/kernel/filesystem.if
@@ -1679,6 +1679,22 @@ interface(`fs_write_ramfs_pipe',`
allow $1 ramfs_t:fifo_file write;
')
+########################################
+##
+## Read and write a named pipe on a ramfs filesystem.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`fs_rw_ramfs_pipe',`
+ gen_require(`
+ type ramfs_t;
+ ')
+
+ allow $1 ramfs_t:fifo_file rw_file_perms;
+')
+
########################################
##
## Write to named socket on a ramfs filesystem.
@@ -2049,6 +2065,23 @@ interface(`fs_create_tmpfs_data',`
')
')
+########################################
+##
+## Read and write generic tmpfs files.
+##
+##
+## The type of the process performing this action.
+##
+#
+interface(`fs_rw_tmpfs_file',`
+ gen_require(`
+ type tmpfs_t;
+ ')
+
+ fs_search_tmpfs($1)
+ allow $1 tmpfs_t:file rw_file_perms;
+')
+
########################################
##
## Read and write character nodes on tmpfs filesystems.
diff --git a/refpolicy/policy/modules/kernel/kernel.te b/refpolicy/policy/modules/kernel/kernel.te
index 5edbef53..9d670f4f 100644
--- a/refpolicy/policy/modules/kernel/kernel.te
+++ b/refpolicy/policy/modules/kernel/kernel.te
@@ -21,6 +21,15 @@ attribute proc_type;
# sysctls
attribute sysctl_type;
+role system_r;
+role sysadm_r;
+role staff_r;
+role user_r;
+
+ifdef(`enable_mls',`
+ role secadm_r;
+')
+
#
# kernel_t is the domain of kernel threads.
# It is also the target type when checking permissions in the system class.
diff --git a/refpolicy/policy/modules/services/apache.if b/refpolicy/policy/modules/services/apache.if
index 00a97c64..8c7f04ef 100644
--- a/refpolicy/policy/modules/services/apache.if
+++ b/refpolicy/policy/modules/services/apache.if
@@ -703,3 +703,19 @@ interface(`apache_append_squirrelmail_data',`
allow $1 httpd_squirrelmail_t:file { getattr append };
')
+
+########################################
+##
+## Search system script state directory.
+##
+##
+## Domain to not audit.
+##
+#
+interface(`apache_search_sys_script_state',`
+ gen_require(`
+ type httpd_sys_script_t;
+ ')
+
+ allow $1 httpd_sys_script_t:dir search;
+')
diff --git a/refpolicy/policy/modules/services/apm.if b/refpolicy/policy/modules/services/apm.if
index 4cac7346..a051c349 100644
--- a/refpolicy/policy/modules/services/apm.if
+++ b/refpolicy/policy/modules/services/apm.if
@@ -97,7 +97,7 @@ interface(`apm_append_log',`
#
interface(`apm_stream_connect',`
gen_require(`
- type apmd_t;
+ type apmd_t, apmd_var_run_t;
')
files_search_pids($1)
diff --git a/refpolicy/policy/modules/services/avahi.if b/refpolicy/policy/modules/services/avahi.if
index 8bc232b9..15b762f1 100644
--- a/refpolicy/policy/modules/services/avahi.if
+++ b/refpolicy/policy/modules/services/avahi.if
@@ -1 +1,20 @@
## mDNS/DNS-SD daemon implementing Apple ZeroConf architecture
+
+########################################
+##
+## Send and receive messages from
+## avahi over dbus.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`avahi_dbus_chat',`
+ gen_require(`
+ type avahi_t;
+ class dbus send_msg;
+ ')
+
+ allow $1 avahi_t:dbus send_msg;
+ allow avahi_t $1:dbus send_msg;
+')
diff --git a/refpolicy/policy/modules/services/avahi.te b/refpolicy/policy/modules/services/avahi.te
index c26bedee..fe04bba3 100644
--- a/refpolicy/policy/modules/services/avahi.te
+++ b/refpolicy/policy/modules/services/avahi.te
@@ -1,5 +1,5 @@
-policy_module(avahi,1.0.1)
+policy_module(avahi,1.0.2)
########################################
#
@@ -90,10 +90,6 @@ optional_policy(`dbus',`
dbus_system_bus_client_template(avahi,avahi_t)
dbus_connect_system_bus(avahi_t)
dbus_send_system_bus_msg(avahi_t)
-
- # FIXME:
- allow avahi_t unconfined_t:dbus send_msg;
- allow unconfined_t avahi_t:dbus send_msg;
')
optional_policy(`nis',`
@@ -107,4 +103,3 @@ optional_policy(`selinuxutil',`
optional_policy(`udev',`
udev_read_db(avahi_t)
')
-
diff --git a/refpolicy/policy/modules/services/bind.te b/refpolicy/policy/modules/services/bind.te
index f5e2d154..a5869ea5 100644
--- a/refpolicy/policy/modules/services/bind.te
+++ b/refpolicy/policy/modules/services/bind.te
@@ -289,9 +289,9 @@ optional_policy(`networkmanager',`
')
# optional_policy(`dbus',`
-# gen_require(`
-# class dbus send_msg;
-# ')
+ gen_require(`
+ class dbus send_msg;
+ ')
allow NetworkManager_t named_t:dbus send_msg;
allow named_t NetworkManager_t:dbus send_msg;
diff --git a/refpolicy/policy/modules/services/cups.if b/refpolicy/policy/modules/services/cups.if
index 5ef539b1..d9182922 100644
--- a/refpolicy/policy/modules/services/cups.if
+++ b/refpolicy/policy/modules/services/cups.if
@@ -1,5 +1,26 @@
## Common UNIX printing system
+########################################
+##
+## Execute cups in the cups domain.
+##
+##
+## The type of the process performing this action.
+##
+#
+interface(`cups_domtrans',`
+ gen_require(`
+ type cupsd_t, cupsd_exec_t;
+ ')
+
+ domain_auto_trans($1,cupsd_exec_t,cupsd_t)
+
+ allow $1 cupsd_t:fd use;
+ allow cupsd_t $1:fd use;
+ allow cupsd_t $1:fifo_file rw_file_perms;
+ allow cupsd_t $1:process sigchld;
+')
+
########################################
##
## Execute cups_config in the cups_config domain.
@@ -21,6 +42,42 @@ interface(`cups_domtrans_config',`
allow cupsd_config_t $1:process sigchld;
')
+########################################
+##
+## Send generic signals to the cups
+## configuration daemon.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`cups_signal_config',`
+ gen_require(`
+ type cupsd_config_t;
+ ')
+
+ allow $1 cupsd_config_t:process signal;
+')
+
+########################################
+##
+## Send and receive messages from
+## cupsd_config over dbus.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`cups_dbus_chat_config',`
+ gen_require(`
+ type cupsd_config_t;
+ class dbus send_msg;
+ ')
+
+ allow $1 cupsd_config_t:dbus send_msg;
+ allow cupsd_config_t $1:dbus send_msg;
+')
+
########################################
##
## Read cups-writable configuration files.
@@ -38,3 +95,39 @@ interface(`cups_read_rw_config',`
allow $1 cupsd_etc_t:dir search_dir_perms;
allow $1 cupsd_rw_etc_t:file { getattr read };
')
+
+########################################
+##
+## Read cups log files.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`cups_read_log',`
+ gen_require(`
+ type cupsd_log_t;
+ ')
+
+ logging_search_logs($1)
+ allow $1 cupsd_log_t:file { getattr read };
+')
+
+########################################
+##
+## Connect to ptal over an unix domain stream socket.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`cups_stream_connect_ptal',`
+ gen_require(`
+ type ptal_t, ptal_var_run_t;
+ ')
+
+ files_search_pids($1)
+ allow $1 ptal_var_run_t:dir search;
+ allow $1 ptal_var_run_t:sock_file write;
+ allow $1 ptal_t:unix_stream_socket connectto;
+')
diff --git a/refpolicy/policy/modules/services/cups.te b/refpolicy/policy/modules/services/cups.te
index b1a3cf3f..041da68b 100644
--- a/refpolicy/policy/modules/services/cups.te
+++ b/refpolicy/policy/modules/services/cups.te
@@ -1,5 +1,5 @@
-policy_module(cups,1.0)
+policy_module(cups,1.0.1)
########################################
#
@@ -149,6 +149,7 @@ fs_search_auto_mountpoints(cupsd_t)
term_dontaudit_use_console(cupsd_t)
auth_domtrans_chk_passwd(cupsd_t)
+auth_dontaudit_read_pam_pid(cupsd_t)
# Filter scripts may be shell scripts, and may invoke progs like /bin/mktemp
corecmd_exec_shell(cupsd_t)
@@ -187,7 +188,7 @@ seutil_dontaudit_read_config(cupsd_t)
sysnet_read_config(cupsd_t)
userdom_dontaudit_use_unpriv_user_fd(cupsd_t)
-userdom_dontaudit_search_sysadm_home_dir(cupsd_t)
+userdom_dontaudit_search_all_users_home(cupsd_t)
# Write to /var/spool/cups.
lpd_manage_spool(cupsd_t)
@@ -198,17 +199,30 @@ ifdef(`targeted_policy',`
files_dontaudit_read_root_file(cupsd_t)
')
+optional_policy(`cron',`
+ cron_use_fd(cupsd_t)
+ cron_read_pipe(cupsd_t)
+')
+
optional_policy(`dbus',`
dbus_system_bus_client_template(cupsd,cupsd_t)
dbus_send_system_bus_msg(cupsd_t)
- allow cupsd_t userdomain:dbus send_msg;
+ userdom_dbus_send_all_users(cupsd_t)
+
+ optional_policy(`hal',`
+ hal_dbus_chat(cupsd_t)
+ ')
')
optional_policy(`hostname',`
hostname_exec(cupsd_t)
')
+optional_policy(`inetd',`
+ inetd_core_service_domain(cupsd_t,cupsd_exec_t,cupsd_t)
+')
+
optional_policy(`mount',`
mount_send_nfs_client_request(cupsd_t)
')
@@ -217,6 +231,15 @@ optional_policy(`nscd',`
nscd_use_socket(cupsd_t)
')
+optional_policy(`portmap',`
+ portmap_udp_sendrecv(cupsd_t)
+')
+
+optional_policy(`samba',`
+ samba_rw_var_files(cupsd_t)
+ # cjp: rw_dir_perms was here, but doesnt make sense
+')
+
optional_policy(`selinuxutil',`
seutil_sigchld_newrole(cupsd_t)
')
@@ -241,56 +264,18 @@ allow cupsd_t devpts_t:dir search;
dontaudit cupsd_t random_device_t:chr_file ioctl;
# temporary solution, we need something better
-allow cupsd_t serial_device:chr_file rw_file_perms;
-
-optional_policy(`logrotate',`
- domain_auto_trans(logrotate_t, cupsd_exec_t, cupsd_t)
-')
-
-optional_policy(`inetd',`
-domain_auto_trans(inetd_t, cupsd_exec_t, cupsd_t)
-')
+#allow cupsd_t serial_device:chr_file rw_file_perms;
# for /etc/printcap
dontaudit cupsd_t etc_t:file write;
-
-
-
-
-# Send to portmap.
-optional_policy(`portmap', `
-allow cupsd_t portmap_t:udp_socket sendto;
-allow portmap_t cupsd_t:udp_socket recvfrom;
-allow portmap_t cupsd_t:udp_socket sendto;
-allow cupsd_t portmap_t:udp_socket recvfrom;
-')
-
-
-
-
-
#
# Satisfy readahead
#
-allow initrc_t cupsd_log_t:file { getattr read };
allow cupsd_t var_t:dir { getattr read search };
allow cupsd_t var_t:file r_file_perms;
allow cupsd_t var_t:lnk_file { getattr read };
-optional_policy(`samba',`
-# cjp: rw_dir_perms here doesnt make sense
-allow cupsd_t samba_var_t:dir rw_dir_perms;
-allow cupsd_t samba_var_t:file rw_file_perms;
-allow cupsd_t samba_var_t:lnk_file { getattr read };
-allow smbd_t cupsd_etc_t:dir search;
-')
-
-optional_policy(`authlogin',`
-dontaudit cupsd_t pam_var_run_t:file { getattr read };
-')
-dontaudit cupsd_t { sysadm_home_dir_t staff_home_dir_t }:dir { getattr search };
-
########################################
#
# PTAL local policy
@@ -358,7 +343,7 @@ miscfiles_read_localization(ptal_t)
sysnet_read_config(ptal_t)
userdom_dontaudit_use_unpriv_user_fd(ptal_t)
-userdom_dontaudit_search_sysadm_home_dir(ptal_t)
+userdom_dontaudit_search_all_users_home(ptal_t)
ifdef(`targeted_policy', `
term_dontaudit_use_unallocated_tty(ptal_t)
@@ -374,14 +359,8 @@ optional_policy(`udev',`
udev_read_db(ptal_t)
')
-allow userdomain ptal_t:unix_stream_socket connectto;
-allow userdomain ptal_var_run_t:sock_file write;
-allow userdomain ptal_var_run_t:dir search;
-
allow initrc_t printer_device_t:chr_file getattr;
-dontaudit ptal_t { sysadm_home_dir_t staff_home_dir_t }:dir { getattr search };
-
allow initrc_t ptal_var_run_t:dir rmdir;
allow initrc_t ptal_var_run_t:fifo_file unlink;
@@ -555,6 +534,8 @@ corecmd_exec_sbin(cupsd_config_t)
corecmd_exec_shell(cupsd_config_t)
domain_use_wide_inherit_fd(cupsd_config_t)
+# killall causes the following
+domain_dontaudit_search_all_domains_state(cupsd_config_t)
files_read_usr_files(cupsd_config_t)
files_read_etc_files(cupsd_config_t)
@@ -577,12 +558,35 @@ sysnet_read_config(cupsd_config_t)
userdom_dontaudit_use_unpriv_user_fd(cupsd_config_t)
userdom_dontaudit_search_sysadm_home_dir(cupsd_config_t)
+ifdef(`distro_redhat',`
+ init_getattr_script_entry_file(cupsd_config_t)
+
+ optional_policy(`rpm',`
+ rpm_read_db(cupsd_config_t)
+ ')
+')
+
ifdef(`targeted_policy', `
term_dontaudit_use_unallocated_tty(cupsd_config_t)
term_dontaudit_use_generic_pty(cupsd_config_t)
files_dontaudit_read_root_file(cupsd_config_t)
')
+optional_policy(`cron',`
+ cron_use_system_job_fd(cupsd_config_t)
+ cron_read_pipe(cupsd_config_t)
+')
+
+optional_policy(`dbus',`
+ dbus_system_bus_client_template(cupsd_config,cupsd_config_t)
+ dbus_connect_system_bus(cupsd_config_t)
+ dbus_send_system_bus_msg(cupsd_config_t)
+
+ optional_policy(`hal',`
+ hal_dbus_chat(cupsd_config_t)
+ ')
+')
+
optional_policy(`hal',`
hal_domtrans(cupsd_config_t)
')
@@ -603,6 +607,10 @@ optional_policy(`nscd',`
nscd_use_socket(cupsd_config_t)
')
+optional_policy(`rpm',`
+ rpm_read_db(cupsd_config_t)
+')
+
optional_policy(`selinuxutil',`
seutil_sigchld_newrole(cupsd_config_t)
')
@@ -611,49 +619,10 @@ optional_policy(`udev',`
udev_read_db(cupsd_config_t)
')
-allow cupsd_config_t devpts_t:dir search;
-allow cupsd_config_t devpts_t:chr_file { getattr ioctl };
-
-ifdef(`distro_redhat', `
- optional_policy(`rpm',`
- allow cupsd_config_t rpm_var_lib_t:dir { getattr search };
- allow cupsd_config_t rpm_var_lib_t:file { getattr read };
- ')
- allow cupsd_config_t initrc_exec_t:file getattr;
-')
-
allow cupsd_config_t var_t:lnk_file read;
-optional_policy(`dbus',`
- dbus_system_bus_client_template(cupsd_config,cupsd_config_t)
- dbus_connect_system_bus(cupsd_config_t)
- dbus_send_system_bus_msg(cupsd_config_t)
-
- allow cupsd_config_t userdomain:dbus send_msg;
- allow userdomain cupsd_config_t:dbus send_msg;
-')
-
-optional_policy(`hal', `
- optional_policy(`dbus',`
- allow { cupsd_t cupsd_config_t } hald_t:dbus send_msg;
- allow hald_t { cupsd_t cupsd_config_t }:dbus send_msg;
- ')
-
- allow hald_t cupsd_config_t:process signal;
-')
-
-# killall causes the following
-dontaudit cupsd_config_t domain:dir { getattr search };
-
-allow cupsd_config_t var_lib_t:dir { getattr search };
-allow cupsd_config_t rpm_var_lib_t:file { getattr read };
allow cupsd_config_t printconf_t:file { getattr read };
-allow cupsd_config_t system_crond_t:fd use;
-allow cupsd_config_t crond_t:fifo_file r_file_perms;
-allow cupsd_t crond_t:fifo_file read;
-allow cupsd_t crond_t:fd use;
-
# Alternatives asks for this
allow cupsd_config_t initrc_exec_t:file getattr;
@@ -664,6 +633,7 @@ ifdef(`targeted_policy', `
allow { cupsd_config_t cupsd_t } unconfined_t:dbus send_msg;
allow unconfined_t cupsd_config_t:dbus send_msg;
allow { cupsd_t cupsd_config_t } unconfined_t:fifo_file read;
+ term_use_generic_pty(cupsd_config_t)
')
########################################
diff --git a/refpolicy/policy/modules/services/finger.te b/refpolicy/policy/modules/services/finger.te
index 6af68c3f..50b67693 100644
--- a/refpolicy/policy/modules/services/finger.te
+++ b/refpolicy/policy/modules/services/finger.te
@@ -100,6 +100,9 @@ miscfiles_read_localization(fingerd_t)
userdom_read_unpriv_user_home_files(fingerd_t)
userdom_dontaudit_use_unpriv_user_fd(fingerd_t)
userdom_dontaudit_search_sysadm_home_dir(fingerd_t)
+# stop it accessing sub-directories, prevents checking a Maildir for new mail,
+# have to change this when we create a type for Maildir
+userdom_dontaudit_search_user_home_dirs(fingerd_t)
ifdef(`targeted_policy',`
term_dontaudit_use_unallocated_tty(fingerd_t)
@@ -130,7 +133,3 @@ optional_policy(`selinuxutil',`
optional_policy(`udev',`
udev_read_db(fingerd_t)
')
-
-# stop it accessing sub-directories, prevents checking a Maildir for new mail,
-# have to change this when we create a type for Maildir
-dontaudit fingerd_t user_home_t:dir search;
diff --git a/refpolicy/policy/modules/services/hal.te b/refpolicy/policy/modules/services/hal.te
index d0c16948..236dceed 100644
--- a/refpolicy/policy/modules/services/hal.te
+++ b/refpolicy/policy/modules/services/hal.te
@@ -1,5 +1,5 @@
-policy_module(hal,1.0.1)
+policy_module(hal,1.0.2)
########################################
#
@@ -134,6 +134,7 @@ optional_policy(`apm',`
optional_policy(`cups',`
cups_domtrans_config(hald_t)
+ cups_signal_config(hald_t)
')
optional_policy(`dbus',`
@@ -187,21 +188,4 @@ optional_policy(`updfstab',`
ifdef(`TODO',`
allow hald_t device_t:dir create_dir_perms;
-
-optional_policy(`hald',`
-allow udev_t hald_t:unix_dgram_socket sendto;
-')
') dnl end TODO
-
-ifdef(`targeted_policy', `
-allow unconfined_t hald_t:dbus send_msg;
-allow hald_t unconfined_t:dbus send_msg;
-')
-
-optional_policy(`updfstab',`
- allow updfstab_t hald_t:dbus send_msg;
- allow hald_t updfstab_t:dbus send_msg;
-')
-
-allow hald_t initrc_t:dbus send_msg;
-allow initrc_t hald_t:dbus send_msg;
diff --git a/refpolicy/policy/modules/services/mailman.te b/refpolicy/policy/modules/services/mailman.te
index 163c2973..e834acae 100644
--- a/refpolicy/policy/modules/services/mailman.te
+++ b/refpolicy/policy/modules/services/mailman.te
@@ -51,9 +51,7 @@ optional_policy(`apache',`
apache_sigchld(mailman_cgi_t)
apache_use_fd(mailman_cgi_t)
apache_dontaudit_append_log(mailman_cgi_t)
-
- # FIXME:
- allow mailman_cgi_t httpd_sys_script_t:dir search;
+ apache_search_sys_script_state(mailman_cgi_t)
')
########################################
diff --git a/refpolicy/policy/modules/services/mta.if b/refpolicy/policy/modules/services/mta.if
index 3b89e100..8abdaba5 100644
--- a/refpolicy/policy/modules/services/mta.if
+++ b/refpolicy/policy/modules/services/mta.if
@@ -36,6 +36,11 @@ interface(`mta_stub',`
#
template(`mta_base_mail_template',`
+ gen_require(`
+ attribute user_mail_domain;
+ type sendmail_exec_t;
+ ')
+
##############################
#
# $1_mail_t declarations
@@ -45,12 +50,8 @@ template(`mta_base_mail_template',`
domain_type($1_mail_t)
domain_entry_file($1_mail_t,sendmail_exec_t)
- optional_policy(`sendmail',`
- type $1_mail_tmp_t;
- files_tmp_file($1_mail_tmp_t)
-
- sendmail_stub($1_mail_t)
- ')
+ type $1_mail_tmp_t;
+ files_tmp_file($1_mail_tmp_t)
##############################
#
@@ -107,6 +108,10 @@ template(`mta_base_mail_template',`
')
optional_policy(`sendmail',`
+ gen_require(`
+ type etc_mail_t, mail_spool_t, mqueue_spool_t;
+ ')
+
allow $1_mail_t $1_mail_tmp_t:dir create_dir_perms;
allow $1_mail_t $1_mail_tmp_t:file create_file_perms;
files_create_tmp_files($1_mail_t, $1_mail_tmp_t, { file dir })
@@ -166,7 +171,8 @@ template(`mta_base_mail_template',`
#
template(`mta_per_userdomain_template',`
gen_require(`
- attribute mailserver_domain, mta_user_agent, user_mail_domain;
+ attribute mailserver_domain, mta_user_agent;
+ attribute mailserver_delivery, user_mail_domain;
type sendmail_exec_t;
')
diff --git a/refpolicy/policy/modules/services/procmail.te b/refpolicy/policy/modules/services/procmail.te
index e0e321a2..bc9e6048 100644
--- a/refpolicy/policy/modules/services/procmail.te
+++ b/refpolicy/policy/modules/services/procmail.te
@@ -6,8 +6,7 @@ policy_module(procmail,1.0.0)
# Declarations
#
-# privhome only works until we define a different type for maildir
-type procmail_t, privhome;
+type procmail_t;
type procmail_exec_t;
domain_type(procmail_t)
domain_entry_file(procmail_t,procmail_exec_t)
@@ -61,6 +60,7 @@ libs_use_shared_libs(procmail_t)
miscfiles_read_localization(procmail_t)
+# only works until we define a different type for maildir
userdom_priveleged_home_dir_manager(procmail_t)
# Do not audit attempts to access /root.
userdom_dontaudit_search_sysadm_home_dir(procmail_t)
diff --git a/refpolicy/policy/modules/services/radius.if b/refpolicy/policy/modules/services/radius.if
index c3b31d77..33cd1ed3 100644
--- a/refpolicy/policy/modules/services/radius.if
+++ b/refpolicy/policy/modules/services/radius.if
@@ -10,7 +10,7 @@
#
interface(`radius_use',`
gen_require(`
- type radius_t;
+ type radiusd_t;
')
allow $1 radiusd_t:udp_socket sendto;
diff --git a/refpolicy/policy/modules/services/samba.if b/refpolicy/policy/modules/services/samba.if
index 3e9a0a5a..34b6d488 100644
--- a/refpolicy/policy/modules/services/samba.if
+++ b/refpolicy/policy/modules/services/samba.if
@@ -213,6 +213,25 @@ interface(`samba_search_var',`
allow $1 samba_var_t:dir search_dir_perms;
')
+########################################
+##
+## Allow the specified domain to
+## read and write samba /var files.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`samba_rw_var_files',`
+ gen_require(`
+ type samba_var_t;
+ ')
+
+ files_search_var($1)
+ allow $1 samba_var_t:dir search_dir_perms;
+ allow $1 samba_var_t:file rw_file_perms;
+')
+
########################################
##
## Allow the specified domain to write to smbmount tcp sockets.
diff --git a/refpolicy/policy/modules/system/authlogin.if b/refpolicy/policy/modules/system/authlogin.if
index d64453ff..0afd82a3 100644
--- a/refpolicy/policy/modules/system/authlogin.if
+++ b/refpolicy/policy/modules/system/authlogin.if
@@ -559,8 +559,6 @@ interface(`auth_exec_pam',`
interface(`auth_read_pam_pid',`
gen_require(`
type pam_var_run_t;
- class dir r_dir_perms;
- class file r_file_perms;
')
files_search_var($1)
@@ -569,6 +567,22 @@ interface(`auth_read_pam_pid',`
allow $1 pam_var_run_t:file r_file_perms;
')
+#######################################
+##
+## Do not audit attemps to read PAM pid files.
+##
+##
+## Domain to not audit.
+##
+#
+interface(`auth_dontaudit_read_pam_pid',`
+ gen_require(`
+ type pam_var_run_t;
+ ')
+
+ dontaudit $1 pam_var_run_t:file { getattr read };
+')
+
########################################
##
## Delete pam PID files.
diff --git a/refpolicy/policy/modules/system/domain.if b/refpolicy/policy/modules/system/domain.if
index d2546fa7..78f2d876 100644
--- a/refpolicy/policy/modules/system/domain.if
+++ b/refpolicy/policy/modules/system/domain.if
@@ -471,6 +471,7 @@ interface(`domain_kill_all_domains',`
allow $1 domain:process sigkill;
allow $1 self:capability kill;
')
+
########################################
##
## Search the process state directory (/proc/pid) of all domains.
@@ -489,6 +490,23 @@ interface(`domain_search_all_domains_state',`
allow $1 domain:dir search;
')
+########################################
+##
+## Do not audit attempts to search the process
+## state directory (/proc/pid) of all domains.
+##
+##
+## Domain to not audit.
+##
+#
+interface(`domain_dontaudit_search_all_domains_state',`
+ gen_require(`
+ attribute domain;
+ ')
+
+ dontaudit $1 domain:dir search_dir_perms;
+')
+
########################################
##
## Read the process state (/proc/pid) of all domains.
diff --git a/refpolicy/policy/modules/system/fstools.te b/refpolicy/policy/modules/system/fstools.te
index 75d62238..4659db96 100644
--- a/refpolicy/policy/modules/system/fstools.te
+++ b/refpolicy/policy/modules/system/fstools.te
@@ -1,5 +1,5 @@
-policy_module(fstools,1.0)
+policy_module(fstools,1.0.1)
########################################
#
@@ -72,6 +72,8 @@ dev_getattr_usbfs_dir(fsadm_t)
fs_search_auto_mountpoints(fsadm_t)
fs_getattr_xattr_fs(fsadm_t)
+fs_rw_ramfs_pipe(fsadm_t)
+fs_rw_tmpfs_file(fsadm_t)
# remount file system to apply changes
fs_remount_xattr_fs(fsadm_t)
# for /dev/shm
@@ -155,10 +157,3 @@ optional_policy(`cron',`
optional_policy(`nis',`
nis_use_ypbind(fsadm_t)
')
-
-ifdef(`TODO',`
-ifdef(`gnome-pty-helper.te', `allow fsadm_t sysadm_gph_t:fd use;')
-') dnl end TODO
-
-allow fsadm_t tmpfs_t:file { read write };
-allow fsadm_t ramfs_t:fifo_file rw_file_perms;
diff --git a/refpolicy/policy/modules/system/init.if b/refpolicy/policy/modules/system/init.if
index 54749bd2..d12b7f2a 100644
--- a/refpolicy/policy/modules/system/init.if
+++ b/refpolicy/policy/modules/system/init.if
@@ -475,6 +475,23 @@ interface(`init_dontaudit_unix_connect_script',`
dontaudit $1 initrc_t:unix_stream_socket connectto;
')
+########################################
+##
+## Get the attribute of init script entrypoint files.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`init_getattr_script_entry_file',`
+ gen_require(`
+ type initrc_exec_t;
+ ')
+
+ files_list_etc($1)
+ allow $1 initrc_exec_t:file getattr;
+')
+
########################################
##
## Read init scripts.
diff --git a/refpolicy/policy/modules/system/init.te b/refpolicy/policy/modules/system/init.te
index c1ca9bdb..28fda4c2 100644
--- a/refpolicy/policy/modules/system/init.te
+++ b/refpolicy/policy/modules/system/init.te
@@ -1,5 +1,5 @@
-policy_module(init,1.0.1)
+policy_module(init,1.0.2)
gen_require(`
class passwd rootok;
@@ -494,6 +494,10 @@ optional_policy(`cpucontrol',`
dev_getattr_cpu(initrc_t)
')
+optional_policy(`cups',`
+ cups_read_log(initrc_t)
+')
+
optional_policy(`dbus',`
dbus_connect_system_bus(initrc_t)
dbus_send_system_bus_msg(initrc_t)
@@ -502,6 +506,10 @@ optional_policy(`dbus',`
optional_policy(`networkmanager',`
networkmanager_dbus_chat(initrc_t)
')
+
+ optional_policy(`updfstab',`
+ updfstab_dbus_chat(initrc_t)
+ ')
')
optional_policy(`ftp',`
diff --git a/refpolicy/policy/modules/system/modutils.te b/refpolicy/policy/modules/system/modutils.te
index 247e9dec..13801fbc 100644
--- a/refpolicy/policy/modules/system/modutils.te
+++ b/refpolicy/policy/modules/system/modutils.te
@@ -1,6 +1,10 @@
policy_module(modutils,1.0)
+gen_require(`
+ bool secure_mode_insmod;
+')
+
########################################
#
# Declarations
diff --git a/refpolicy/policy/modules/system/pcmcia.te b/refpolicy/policy/modules/system/pcmcia.te
index a189206a..0bad501a 100644
--- a/refpolicy/policy/modules/system/pcmcia.te
+++ b/refpolicy/policy/modules/system/pcmcia.te
@@ -55,6 +55,8 @@ kernel_dontaudit_getattr_message_if(cardmgr_t)
bootloader_search_kernel_modules(cardmgr_t)
dev_read_sysfs(cardmgr_t)
+dev_manage_cardmgr(cardmgr_t)
+dev_create_cardmgr(cardmgr_t)
dev_getattr_all_chr_files(cardmgr_t)
dev_getattr_all_blk_files(cardmgr_t)
# for SSP
@@ -149,6 +151,5 @@ optional_policy(`udev',`
# Create device files in /tmp.
# cjp: why is this created all over the place?
-allow cardmgr_t cardmgr_dev_t:{ chr_file blk_file } manage_file_perms;
-allow cardmgr_t { var_run_t cardmgr_var_run_t device_t tmp_t }:dir rw_dir_perms;
-type_transition cardmgr_t { var_run_t cardmgr_var_run_t device_t tmp_t }:{ chr_file blk_file } cardmgr_dev_t;
+allow cardmgr_t { var_run_t cardmgr_var_run_t tmp_t }:dir rw_dir_perms;
+type_transition cardmgr_t { var_run_t cardmgr_var_run_t tmp_t }:{ chr_file blk_file } cardmgr_dev_t;
diff --git a/refpolicy/policy/modules/system/selinuxutil.te b/refpolicy/policy/modules/system/selinuxutil.te
index 06433bf4..9b649fd4 100644
--- a/refpolicy/policy/modules/system/selinuxutil.te
+++ b/refpolicy/policy/modules/system/selinuxutil.te
@@ -13,6 +13,18 @@ gen_require(`
attribute can_write_binary_policy;
attribute can_relabelto_binary_policy;
+#
+# selinux_config_t is the type applied to
+# /etc/selinux/config
+#
+# cjp: this is out of order due to rules
+# in the domain_type interface
+# (fix dup decl)
+type selinux_config_t;
+files_type(selinux_config_t)
+kernel_list_from(selinux_config_t)
+kernel_read_file_from(selinux_config_t)
+
type checkpolicy_t, can_write_binary_policy;
domain_type(checkpolicy_t)
role system_r types checkpolicy_t;
@@ -81,15 +93,6 @@ domain_type(run_init_t)
type run_init_exec_t;
domain_entry_file(run_init_t,run_init_exec_t)
-#
-# selinux_config_t is the type applied to
-# /etc/selinux/config
-#
-type selinux_config_t;
-files_type(selinux_config_t)
-kernel_list_from(selinux_config_t)
-kernel_read_file_from(selinux_config_t)
-
type setfiles_t, can_relabelto_binary_policy;
domain_obj_id_change_exempt(setfiles_t)
domain_type(setfiles_t)
diff --git a/refpolicy/policy/modules/system/sysnetwork.te b/refpolicy/policy/modules/system/sysnetwork.te
index 8347a597..c1a479f8 100644
--- a/refpolicy/policy/modules/system/sysnetwork.te
+++ b/refpolicy/policy/modules/system/sysnetwork.te
@@ -173,8 +173,12 @@ optional_policy(`dbus',`
domain_auto_trans(system_dbusd_t, dhcpc_exec_t, dhcpc_t)
- allow { NetworkManager_t initrc_t } dhcpc_t:dbus send_msg;
- allow dhcpc_t { NetworkManager_t initrc_t }:dbus send_msg;
+ allow initrc_t dhcpc_t:dbus send_msg;
+ allow dhcpc_t initrc_t:dbus send_msg;
+
+ optional_policy(`networkmanager',`
+ networkmanager_dbus_chat(dhcpc_t)
+ ')
ifdef(`unconfined.te', `
allow unconfined_t dhcpc_t:dbus send_msg;
diff --git a/refpolicy/policy/modules/system/udev.te b/refpolicy/policy/modules/system/udev.te
index 2a7a1ad6..efe4fa83 100644
--- a/refpolicy/policy/modules/system/udev.te
+++ b/refpolicy/policy/modules/system/udev.te
@@ -1,5 +1,5 @@
-policy_module(udev,1.0)
+policy_module(udev,1.0.1)
########################################
#
@@ -176,6 +176,10 @@ optional_policy(`dbus',`
dbus_system_bus_client_template(udev,udev_t)
')
+optional_policy(`hal',`
+ hal_dgram_sendto(udev_t)
+')
+
optional_policy(`hotplug',`
hotplug_read_config(udev_t)
')
@@ -192,8 +196,8 @@ optional_policy(`sysnetwork',`
sysnet_domtrans_dhcpc(udev_t)
')
-#optional_policy(`xserver',`
-# xserver_read_xdm_pid(udev_t)
+#optional_policy(`xdm',`
+# xdm_read_pid(udev_t)
#')
ifdef(`TODO',`
diff --git a/refpolicy/policy/modules/system/unconfined.te b/refpolicy/policy/modules/system/unconfined.te
index 7348834c..8160f15e 100644
--- a/refpolicy/policy/modules/system/unconfined.te
+++ b/refpolicy/policy/modules/system/unconfined.te
@@ -1,5 +1,5 @@
-policy_module(unconfined,1.0.2)
+policy_module(unconfined,1.0.3)
########################################
#
@@ -60,6 +60,14 @@ ifdef(`targeted_policy',`
optional_policy(`dbus',`
dbus_stub(unconfined_t)
+ optional_policy(`avahi',`
+ avahi_dbus_chat(unconfined_t)
+ ')
+
+ optional_policy(`hal',`
+ hal_dbus_chat(unconfined_t)
+ ')
+
optional_policy(`networkmanager',`
networkmanager_dbus_chat(unconfined_t)
')
diff --git a/refpolicy/policy/modules/system/userdomain.if b/refpolicy/policy/modules/system/userdomain.if
index fdd932b3..6d775a8e 100644
--- a/refpolicy/policy/modules/system/userdomain.if
+++ b/refpolicy/policy/modules/system/userdomain.if
@@ -322,9 +322,17 @@ template(`base_user_template',`
canna_stream_connect($1_t)
')
+ optional_policy(`cups',`
+ cups_stream_connect_ptal($1_t)
+ ')
+
optional_policy(`dbus',`
dbus_system_bus_client_template($1,$1_t)
+ optional_policy(`cups',`
+ cups_dbus_chat_config($1_t)
+ ')
+
optional_policy(`hal',`
hal_dbus_chat($1_t)
')
@@ -2569,7 +2577,7 @@ interface(`userdom_signal_all_users',`
## Domain allowed access.
##
#
-interface(`userdom_sigcld_all_users',`
+interface(`userdom_sigchld_all_users',`
gen_require(`
attribute userdomain;
')
@@ -2577,6 +2585,23 @@ interface(`userdom_sigcld_all_users',`
allow $1 userdomain:process sigchld;
')
+########################################
+##
+## Send a dbus message to all user domains.
+##
+##
+## Domain allowed access.
+##
+#
+interface(`userdom_dbus_send_all_users',`
+ gen_require(`
+ attribute userdomain;
+ class dbus send_msg;
+ ')
+
+ allow $1 userdomain:dbus send_msg;
+')
+
########################################
##
## Unconfined access to user domains.