[selinux-policy: 86/3172] add tty_device_t and devpts_t chr_file interfaces
Daniel J Walsh
dwalsh at fedoraproject.org
Thu Oct 7 19:12:35 UTC 2010
commit de2cee68172ecbe1d586547e080c5f3ff32b2141
Author: Chris PeBenito <cpebenito at tresys.com>
Date: Mon May 2 18:42:10 2005 +0000
add tty_device_t and devpts_t chr_file interfaces
refpolicy/policy/modules/kernel/terminal.if | 113 ++++++++++++++++++++-------
1 files changed, 85 insertions(+), 28 deletions(-)
---
diff --git a/refpolicy/policy/modules/kernel/terminal.if b/refpolicy/policy/modules/kernel/terminal.if
index bf48426..0640dec 100644
--- a/refpolicy/policy/modules/kernel/terminal.if
+++ b/refpolicy/policy/modules/kernel/terminal.if
@@ -27,6 +27,24 @@ devices_list_device_nodes_depend
########################################
#
+# terminal_use_all_terminals(domain,[`optional'])
+#
+define(`terminal_use_all_terminals',`
+requires_block_template(terminal_use_all_terminals_depend,$2)
+devices_list_device_nodes($1,optional)
+allow $1 devpts_t:dir { getattr read search };
+allow $1 { console_device_t devtty_t ttynode ptynode }:chr_file { read write };
+')
+
+define(`terminal_use_all_terminals_depend',`
+attribute ttynode, ptynode;
+type console_device_t, devtty_t, devpts_t;
+class chr_file { read write };
+devices_list_device_nodes_depend
+')
+
+########################################
+#
# terminal_use_console(domain,[`optional'])
#
define(`terminal_use_console',`
@@ -89,39 +107,65 @@ devices_list_device_nodes_depend
########################################
#
-# terminal_use_all_terminals(domain,[`optional'])
+# terminal_reset_physical_terminal_labels(domain)
#
-define(`terminal_use_all_terminals',`
-requires_block_template(terminal_use_all_terminals_depend,$2)
-devices_list_device_nodes($1,optional)
-allow $1 devpts_t:dir { getattr read search };
-allow $1 { console_device_t devtty_t ttynode ptynode }:chr_file { read write };
+define(`terminal_reset_physical_terminal_labels',`
+requires_block_template(terminal_reset_physical_terminal_labels_depend)
+devices_list_device_nodes($1)
+allow $1 ttynode:chr_file relabelfrom;
+allow $1 tty_device_t:chr_file relabelto;
')
-define(`terminal_use_all_terminals_depend',`
-attribute ttynode, ptynode;
-type console_device_t, devtty_t, devpts_t;
-class chr_file { read write };
+define(`terminal_reset_physical_terminal_labels_depend',`
+attribute ttynode;
+type tty_device_t;
+class chr_file { relabelfrom relabelto };
devices_list_device_nodes_depend
')
########################################
#
-# terminal_reset_labels(domain,[`optional'])
+# terminal_use_general_physical_terminal(domain)
+#
+define(`terminal_use_general_physical_terminal',`
+requires_block_template(terminal_use_general_physical_terminal_depend)
+devices_list_device_nodes($1)
+allow $1 tty_device_t:chr_file { read write };
+')
+
+define(`terminal_use_general_physical_terminal_depend',`
+type tty_device_t;
+class chr_file { read write };
+')
+
+########################################
#
-define(`terminal_reset_labels',`
-requires_block_template(terminal_reset_labels_depend,$2)
+# terminal_ignore_use_general_physical_terminal(domain)
+#
+define(`terminal_ignore_use_general_physical_terminal',`
+requires_block_template(terminal_ignore_use_general_physical_terminal_depend)
+dontaudit $1 tty_device_t:chr_file { read write };
+')
+
+define(`terminal_ignore_use_general_physical_terminal_depend',`
+type tty_device_t;
+class chr_file { read write };
+')
+
+########################################
+#
+# terminal_get_user_terminal_attributes(domain,[`optional'])
+#
+define(`terminal_get_user_terminal_attributes',`
+requires_block_template(terminal_get_user_terminal_attributes_depend,$2)
devices_list_device_nodes($1,optional)
-allow $1 ttynode:chr_file relabelfrom;
-allow $1 tty_device_t:chr_file relabelto;
+allow $1 ttynode:chr_file getattr;
')
-define(`terminal_reset_labels_depend',`
+define(`terminal_get_user_terminal_attributes_depend',`
attribute ttynode;
-type tty_device_t;
-class chr_file { relabelfrom relabelto };
+class chr_file getattr;
devices_list_device_nodes_depend
-kernel_relabeling_privilege_depend
')
########################################
@@ -156,16 +200,29 @@ class dir { getattr search read };
########################################
#
-# terminal_get_user_terminal_attributes(domain,[`optional'])
+# terminal_use_general_pseudoterminal(domain)
#
-define(`terminal_get_user_terminal_attributes',`
-requires_block_template(terminal_get_user_terminal_attributes_depend,$2)
-devices_list_device_nodes($1,optional)
-allow $1 ttynode:chr_file getattr;
+define(`terminal_use_general_pseudoterminal',`
+requires_block_template(terminal_use_general_pseudoterminal_depend)
+devices_list_device_nodes($1)
+allow $1 devpts_t:chr_file { read write };
')
-define(`terminal_get_user_terminal_attributes_depend',`
-attribute ttynode;
-class chr_file getattr;
-devices_list_device_nodes_depend
+define(`terminal_use_general_pseudoterminal_depend',`
+type devpts_t;
+class chr_file { read write };
+')
+
+########################################
+#
+# terminal_ignore_use_general_pseudoterminal(domain)
+#
+define(`terminal_ignore_use_general_pseudoterminal',`
+requires_block_template(terminal_ignore_use_general_pseudoterminal_depend)
+dontaudit $1 devpts_t:chr_file { read write };
+')
+
+define(`terminal_ignore_use_general_pseudoterminal_depend',`
+type devpts_t;
+class chr_file { read write };
')
More information about the scm-commits
mailing list