diff --git a/refpolicy/policy/modules/kernel/terminal.if b/refpolicy/policy/modules/kernel/terminal.if
index a91c10714..1d3e76d13 100644
--- a/refpolicy/policy/modules/kernel/terminal.if
+++ b/refpolicy/policy/modules/kernel/terminal.if
@@ -3,16 +3,16 @@
########################################
#
-# terminal_make_pseudoterminal(type)
+# term_make_pty(type)
#
-define(`terminal_make_pseudoterminal',`
+define(`term_make_pty',`
requires_block_template(`$0'_depend)
allow $1 devpts_t:filesystem associate;
typeattribute $1 ptynode;
')
-define(`terminal_make_pseudoterminal_depend',`
+define(`term_make_pty_depend',`
attribute ptynode;
type devpts_t;
@@ -21,25 +21,45 @@ define(`terminal_make_pseudoterminal_depend',`
')
########################################
+##
+##
+## Transform specified type into a user
+## pty type. Interactive ptys will be relabeled
+##
+##
+##
+## An object type that will applied to a pty.
+##
+##
+## An object type that will applied to a pty.
+##
+##
#
-# terminal_make_user_pseudoterminal(domain,type)
-#
-define(`terminal_make_user_pseudoterminal',`
+define(`term_make_user_pty',`
requires_block_template(`$0'_depend)
- terminal_make_pseudoterminal($1)
+ term_make_pty($1)
type_change $1 server_ptynode:chr_file $2;
')
-define(`terminal_make_user_pseudoterminal_depend',`
+define(`term_make_user_pty_depend',`
attribute server_ptynode;
')
+
########################################
+##
+##
+## Transform specified type into an interactive
+## pty type. This allows it to be relabeled via
+## type change by login programs such as ssh.
+##
+##
+## An object type that will applied to a pty.
+##
+##
#
-# terminal_make_service_pseudoterminal(type)
-#
-define(`terminal_make_service_pseudoterminal',`
+define(`term_make_interactive_pty',`
requires_block_template(`$0'_depend)
terminal_make_pseudoterminal($1)
@@ -52,9 +72,9 @@ define(`terminal_make_service_pseudoterminal_depend',`
########################################
#
-# terminal_make_physical_terminal(domain,type)
+# term_make_tty(domain,type)
#
-define(`terminal_make_physical_terminal',`
+define(`term_make_tty',`
requires_block_template(`$0'_depend)
typeattribute $2 ttynode;
@@ -71,7 +91,7 @@ define(`terminal_make_physical_terminal',`
')
')
-define(`terminal_make_physical_terminal_depend',`
+define(`term_make_tty_depend',`
attribute ttynode;
type tty_device_t;
@@ -79,9 +99,9 @@ define(`terminal_make_physical_terminal_depend',`
########################################
#
-# terminal_create_private_pseudoterminal(domain,ptytype)
+# term_create_pty(domain,ptytype)
#
-define(`terminal_create_private_pseudoterminal',`
+define(`term_create_pty',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
@@ -92,7 +112,7 @@ define(`terminal_create_private_pseudoterminal',`
type_transition $1 devpts_t:chr_file $2;
')
-define(`terminal_create_pseudoterminal_depend',`
+define(`term_create_pty_depend',`
type ptmx_t, devpts_t;
class filesystem getattr;
@@ -102,9 +122,9 @@ define(`terminal_create_pseudoterminal_depend',`
########################################
#
-# terminal_use_all_terminals(domain)
+# term_use_all_terminals(domain)
#
-define(`terminal_use_all_terminals',`
+define(`term_use_all_terminals',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
@@ -112,7 +132,7 @@ define(`terminal_use_all_terminals',`
allow $1 { console_device_t tty_device_t ttynode ptynode }:chr_file rw_file_perms;
')
-define(`terminal_use_all_terminals_depend',`
+define(`term_use_all_terminals_depend',`
attribute ttynode, ptynode;
type console_device_t, devpts_t, tty_device_t;
@@ -122,7 +142,7 @@ define(`terminal_use_all_terminals_depend',`
')
########################################
-##
+##
##
## Write to the console.
##
@@ -132,20 +152,20 @@ define(`terminal_use_all_terminals_depend',`
##
##
#
-define(`terminal_write_console',`
+define(`term_write_console',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 console_device_t:chr_file write;
')
-define(`terminal_use_console_depend',`
+define(`term_use_console_depend',`
type console_device_t;
class chr_file write;
')
########################################
-##
+##
##
## Read from and write to the console.
##
@@ -155,21 +175,21 @@ define(`terminal_use_console_depend',`
##
##
#
-define(`terminal_use_console',`
+define(`term_use_console',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 console_device_t:chr_file rw_file_perms;
')
-define(`terminal_use_console_depend',`
+define(`term_use_console_depend',`
type console_device_t;
class chr_file rw_file_perms;
')
########################################
-##
+##
##
## Do not audit read from or write to the console.
##
@@ -179,13 +199,13 @@ define(`terminal_use_console_depend',`
##
##
#
-define(`terminal_ignore_use_console',`
+define(`term_dontaudit_use_console',`
requires_block_template(`$0'_depend)
dontaudit $1 console_device_t:chr_file { read write };
')
-define(`terminal_ignore_use_console_depend',`
+define(`term_dontaudit_use_console_depend',`
type console_device_t;
class chr_file { read write };
@@ -193,16 +213,16 @@ define(`terminal_ignore_use_console_depend',`
########################################
#
-# terminal_set_console_attributes(domain)
+# term_setattr_console(domain)
#
-define(`terminal_set_console_attributes',`
+define(`term_setattr_console',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 console_device_t:chr_file setattr;
')
-define(`terminal_set_console_attributes_depend',`
+define(`term_setattr_console_depend',`
type console_device_t;
class chr_file setattr;
@@ -210,16 +230,16 @@ define(`terminal_set_console_attributes_depend',`
########################################
#
-# terminal_list_pseudoterminals(domain)
+# term_list_ptys(domain)
#
-define(`terminal_list_pseudoterminals',`
+define(`term_list_ptys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 devpts_t:dir r_dir_perms;
')
-define(`terminal_list_pseudoterminals_depend',`
+define(`term_list_ptys_depend',`
type devpts_t;
class dir r_dir_perms;
@@ -227,15 +247,15 @@ define(`terminal_list_pseudoterminals_depend',`
########################################
#
-# terminal_ignore_list_pseudoterminals(domain)
+# term_dontaudit_list_ptys(domain)
#
-define(`terminal_ignore_list_pseudoterminals',`
+define(`term_dontaudit_list_ptys',`
requires_block_template(`$0'_depend)
dontaudit $1 devpts_t:dir { getattr search read };
')
-define(`terminal_ignore_list_pseudoterminals_depend',`
+define(`term_dontaudit_list_ptys_depend',`
type devpts_t;
class dir { getattr search read };
@@ -243,16 +263,16 @@ define(`terminal_ignore_list_pseudoterminals_depend',`
########################################
#
-# terminal_use_general_pseudoterminal(domain)
+# term_use_generic_pty(domain)
#
-define(`terminal_use_general_pseudoterminal',`
+define(`term_use_generic_pty',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 devpts_t:chr_file { read write };
')
-define(`terminal_use_general_pseudoterminal_depend',`
+define(`term_use_generic_pty_depend',`
type devpts_t;
class chr_file { read write };
@@ -260,15 +280,15 @@ define(`terminal_use_general_pseudoterminal_depend',`
########################################
#
-# terminal_ignore_use_general_pseudoterminal(domain)
+# term_dontaudit_use_generic_pty(domain)
#
-define(`terminal_ignore_use_general_pseudoterminal',`
+define(`term_dontaudit_use_generic_pty',`
requires_block_template(`$0'_depend)
dontaudit $1 devpts_t:chr_file { read write };
')
-define(`terminal_ignore_use_general_pseudoterminal_depend',`
+define(`term_dontaudit_use_generic_pty_depend',`
type devpts_t;
class chr_file { read write };
@@ -276,16 +296,16 @@ define(`terminal_ignore_use_general_pseudoterminal_depend',`
########################################
#
-# terminal_use_controlling_terminal(domain)
+# term_use_controlling_terminal(domain)
#
-define(`terminal_use_controlling_terminal',`
+define(`term_use_controlling_terminal',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 devtty_t:chr_file { getattr read write ioctl };
')
-define(`terminal_use_controlling_terminal_depend',`
+define(`term_use_controlling_terminal_depend',`
type devtty_t;
class chr_file { getattr read write ioctl };
@@ -293,15 +313,15 @@ define(`terminal_use_controlling_terminal_depend',`
########################################
#
-# terminal_ignore_use_pseudoterminal_multiplexer(domain)
+# term_dontaudit_rw_ptmx(domain)
#
-define(`terminal_ignore_use_pseudoterminal_multiplexer',`
+define(`term_dontaudit_rw_ptmx',`
requires_block_template(`$0'_depend)
dontaudit $1 ptmx_t:chr_file { getattr read write };
')
-define(`terminal_ignore_use_pseudoterminal_multiplexer_depend',`
+define(`term_dontaudit_rw_ptmx_depend',`
type ptmx_t;
class chr_file { getattr read write };
@@ -309,9 +329,9 @@ define(`terminal_ignore_use_pseudoterminal_multiplexer_depend',`
########################################
#
-# terminal_get_all_private_pseudoterminal_attributes(domain)
+# term_getattr_all_ptys(domain)
#
-define(`terminal_get_all_private_pseudoterminal_attributes',`
+define(`term_getattr_all_ptys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
@@ -319,7 +339,7 @@ define(`terminal_get_all_private_pseudoterminal_attributes',`
allow $1 ptynode:chr_file getattr;
')
-define(`terminal_get_all_private_pseudoterminal_attributes_depend',`
+define(`term_getattr_all_ptys_depend',`
attribute ptynode;
class dir r_dir_perms;
@@ -328,9 +348,9 @@ define(`terminal_get_all_private_pseudoterminal_attributes_depend',`
########################################
#
-# terminal_use_all_private_pseudoterminals(domain)
+# term_use_all_private_ptys(domain)
#
-define(`terminal_use_all_private_pseudoterminals',`
+define(`term_use_all_private_ptys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
@@ -338,7 +358,7 @@ define(`terminal_use_all_private_pseudoterminals',`
allow $1 ptynode:chr_file { getattr read write ioctl };
')
-define(`terminal_use_all_private_pseudoterminals_depend',`
+define(`term_use_all_private_ptys_depend',`
attribute ptynode;
class dir r_dir_perms;
@@ -347,15 +367,15 @@ define(`terminal_use_all_private_pseudoterminals_depend',`
########################################
#
-# terminal_ignore_use_all_private_pseudoterminals(domain)
+# term_dontaudit_use_all_private_ptys(domain)
#
-define(`terminal_ignore_use_all_private_pseudoterminals',`
+define(`term_dontaudit_use_all_private_ptys',`
requires_block_template(`$0'_depend)
dontaudit $1 ptynode:chr_file { read write };
')
-define(`terminal_ignore_use_all_private_pseudoterminals_depend',`
+define(`term_dontaudit_use_all_private_ptys_depend',`
attribute ptynode;
class chr_file { read write };
@@ -363,16 +383,16 @@ define(`terminal_ignore_use_all_private_pseudoterminals_depend',`
########################################
#
-# terminal_get_general_physical_terminal_attributes(domain)
+# term_gettattr_unallocated_ttys(domain)
#
-define(`terminal_get_general_physical_terminal_attributes',`
+define(`term_gettattr_unallocated_ttys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 tty_device_t:chr_file getattr;
')
-define(`terminal_get_general_physical_terminal_attributes_depend',`
+define(`term_gettattr_unallocated_ttys_depend',`
type tty_device_t;
class chr_file getattr;
@@ -380,16 +400,16 @@ define(`terminal_get_general_physical_terminal_attributes_depend',`
########################################
#
-# terminal_set_general_physical_terminal_attributes(domain)
+# term_settattr_unallocated_ttys(domain)
#
-define(`terminal_set_general_physical_terminal_attributes',`
+define(`term_settattr_unallocated_ttys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 tty_device_t:chr_file setattr;
')
-define(`terminal_set_general_physical_terminal_attributes_depend',`
+define(`term_settattr_unallocated_ttys_depend',`
type tty_device_t;
class chr_file setattr;
@@ -397,16 +417,16 @@ define(`terminal_set_general_physical_terminal_attributes_depend',`
########################################
#
-# terminal_relabel_general_physical_terminal(domain)
+# term_relabel_unallocated_tty(domain)
#
-define(`terminal_relabel_general_physical_terminal',`
+define(`term_relabel_unallocated_tty',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 tty_device_t:chr_file { relabelfrom relabelto };
')
-define(`terminal_relabel_general_physical_terminal_depend',`
+define(`term_relabel_unallocated_tty_depend',`
type tty_device_t;
class chr_file { relabelfrom relabelto };
@@ -414,9 +434,9 @@ define(`terminal_relabel_general_physical_terminal_depend',`
########################################
#
-# terminal_reset_physical_terminal_labels(domain)
+# term_reset_tty_labels(domain)
#
-define(`terminal_reset_physical_terminal_labels',`
+define(`term_reset_tty_labels',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
@@ -424,7 +444,7 @@ define(`terminal_reset_physical_terminal_labels',`
allow $1 tty_device_t:chr_file relabelto;
')
-define(`terminal_reset_physical_terminal_labels_depend',`
+define(`term_reset_tty_labels_depend',`
attribute ttynode;
type tty_device_t;
@@ -432,9 +452,9 @@ define(`terminal_reset_physical_terminal_labels_depend',`
')
########################################
-##
+##
##
-## Write to general ttys. Has a backchannel of
+## Write to all unallocated ttys. Has a backchannel of
## getting all tty attributes.
##
##
@@ -443,14 +463,14 @@ define(`terminal_reset_physical_terminal_labels_depend',`
##
##
#
-define(`terminal_write_general_physical_terminal',`
+define(`term_write_general_tty',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 tty_device_t:chr_file { getattr write };
')
-define(`terminal_write_general_physical_terminal_depend',`
+define(`term_write_general_tty_depend',`
type tty_device_t;
class chr_file { getattr write };
@@ -458,16 +478,16 @@ define(`terminal_write_general_physical_terminal_depend',`
########################################
#
-# terminal_use_general_physical_terminal(domain)
+# term_use_unallocated_tty(domain)
#
-define(`terminal_use_general_physical_terminal',`
+define(`term_use_unallocated_tty',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 tty_device_t:chr_file { getattr read write ioctl };
')
-define(`terminal_use_general_physical_terminal_depend',`
+define(`term_use_unallocated_tty_depend',`
type tty_device_t;
class chr_file { getattr read write ioctl };
@@ -475,15 +495,15 @@ define(`terminal_use_general_physical_terminal_depend',`
########################################
#
-# terminal_ignore_use_general_physical_terminal(domain)
+# term_dontaudit_use_unallocated_tty(domain)
#
-define(`terminal_ignore_use_general_physical_terminal',`
+define(`term_dontaudit_use_unallocated_tty',`
requires_block_template(`$0'_depend)
dontaudit $1 tty_device_t:chr_file { read write };
')
-define(`terminal_ignore_use_general_physical_terminal_depend',`
+define(`term_dontaudit_use_unallocated_tty_depend',`
type tty_device_t;
class chr_file { read write };
@@ -491,16 +511,16 @@ define(`terminal_ignore_use_general_physical_terminal_depend',`
########################################
#
-# terminal_get_all_private_physical_terminal_attributes(domain)
+# term_getattr_all_private_ttys(domain)
#
-define(`terminal_get_all_private_physical_terminal_attributes',`
+define(`term_getattr_all_private_ttys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 ttynode:chr_file getattr;
')
-define(`terminal_get_all_private_physical_terminal_attributes_depend',`
+define(`term_getattr_all_private_ttys_depend',`
attribute ttynode;
class chr_file getattr;
@@ -508,16 +528,16 @@ define(`terminal_get_all_private_physical_terminal_attributes_depend',`
########################################
#
-# terminal_set_all_private_physical_terminal_attributes(domain)
+# term_setattr_all_private_ttys(domain)
#
-define(`terminal_set_all_private_physical_terminal_attributes',`
+define(`term_setattr_all_private_ttys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 ttynode:chr_file setattr;
')
-define(`terminal_set_all_private_physical_terminal_attributes_depend',`
+define(`term_setattr_all_private_ttys_depend',`
attribute ttynode;
class chr_file setattr;
@@ -525,15 +545,15 @@ define(`terminal_set_all_private_physical_terminal_attributes_depend',`
########################################
#
-# terminal_ignore_get_all_private_physical_terminal_attributes(domain)
+# term_dontaudit_getattr_all_private_ttys(domain)
#
-define(`terminal_ignore_get_all_private_physical_terminal_attributes',`
+define(`term_dontaudit_getattr_all_private_ttys',`
requires_block_template(`$0'_depend)
dontaudit $1 ttynode:chr_file getattr;
')
-define(`terminal_ignore_get_all_private_physical_terminal_attributes_depend',`
+define(`term_dontaudit_getattr_all_private_ttys_depend',`
attribute ttynode;
class chr_file getattr;
@@ -541,23 +561,23 @@ define(`terminal_ignore_get_all_private_physical_terminal_attributes_depend',`
########################################
#
-# terminal_relabel_all_private_physical_terminals(domain)
+# term_relabel_all_private_ttys(domain)
#
-define(`terminal_relabel_all_private_physical_terminals',`
+define(`term_relabel_all_private_ttys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 ttynode:chr_file { relabelfrom relabelto };
')
-define(`terminal_relabel_all_private_physical_terminals_depend',`
+define(`term_relabel_all_private_ttys_depend',`
attribute ttynode;
class chr_file { relabelfrom relabelto };
')
########################################
-##
+##
##
## Write to all private ttys. Has a backchannel of
## getting all private tty attributes.
@@ -568,14 +588,14 @@ define(`terminal_relabel_all_private_physical_terminals_depend',`
##
##
#
-define(`terminal_write_all_private_physical_terminals',`
+define(`term_write_all_private_ttys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 ttynode:chr_file { getattr write };
')
-define(`terminal_write_all_private_physical_terminals_depend',`
+define(`term_write_all_private_ttys_depend',`
attribute ttynode;
class chr_file { getattr write };
@@ -583,16 +603,16 @@ define(`terminal_write_all_private_physical_terminals_depend',`
########################################
#
-# terminal_use_all_private_physical_terminals(domain)
+# term_use_all_private_ttys(domain)
#
-define(`terminal_use_all_private_physical_terminals',`
+define(`term_use_all_private_ttys',`
requires_block_template(`$0'_depend)
devices_list_device_nodes($1)
allow $1 ttynode:chr_file { getattr read write ioctl };
')
-define(`terminal_use_all_private_physical_terminals_depend',`
+define(`term_use_all_private_ttys_depend',`
attribute ttynode;
class chr_file { getattr read write ioctl };
@@ -600,15 +620,15 @@ define(`terminal_use_all_private_physical_terminals_depend',`
########################################
#
-# terminal_ignore_use_all_private_physical_terminals(domain)
+# term_dontaudit_use_all_private_ttys(domain)
#
-define(`terminal_ignore_use_all_private_physical_terminals',`
+define(`term_dontaudit_use_all_private_ttys',`
requires_block_template(`$0'_depend)
dontaudit $1 ttynode:chr_file { read write };
')
-define(`terminal_ignore_use_all_private_physical_terminals_depend',`
+define(`term_dontaudit_use_all_private_ttys_depend',`
attribute ttynode;
class chr_file { read write };