## Point to Point Protocol daemon creates links in ppp networks. ######################################## ## ## Create, read, write, and delete ## ppp home files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_manage_home_files',` gen_require(` type ppp_home_t; ') userdom_search_user_home_dirs($1) allow $1 ppp_home_t:file manage_file_perms; ') ######################################## ## ## Read ppp user home content files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_home_files',` gen_require(` type ppp_home_t; ') userdom_search_user_home_dirs($1) allow $1 ppp_home_t:file read_file_perms; ') ######################################## ## ## Relabel ppp home files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_relabel_home_files',` gen_require(` type ppp_home_t; ') userdom_search_user_home_dirs($1) allow $1 ppp_home_t:file relabel_file_perms; ') ######################################## ## ## Create objects in user home ## directories with the ppp home type. ## ## ## ## Domain allowed access. ## ## ## ## ## Class of the object being created. ## ## ## ## ## The name of the object being created. ## ## # interface(`ppp_home_filetrans_ppp_home',` gen_require(` type ppp_home_t; ') userdom_user_home_dir_filetrans($1, ppp_home_t, $2, $3) ') ######################################## ## ## Inherit and use ppp file discriptors. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_use_fds',` gen_require(` type pppd_t; ') allow $1 pppd_t:fd use; ') ######################################## ## ## Do not audit attempts to inherit ## and use ppp file discriptors. ## ## ## ## Domain to not audit. ## ## # interface(`ppp_dontaudit_use_fds',` gen_require(` type pppd_t; ') dontaudit $1 pppd_t:fd use; ') ######################################## ## ## Send child terminated signals to ppp. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_sigchld',` gen_require(` type pppd_t; ') allow $1 pppd_t:process sigchld; ') ######################################## ## ## Send kill signals to ppp. ## ## ## ## Domain allowed access. ## ## # # interface(`ppp_kill',` gen_require(` type pppd_t; ') allow $1 pppd_t:process sigkill; ') ######################################## ## ## Send generic signals to ppp. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_signal',` gen_require(` type pppd_t; ') allow $1 pppd_t:process signal; ') ######################################## ## ## Send null signals to ppp. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_signull',` gen_require(` type pppd_t; ') allow $1 pppd_t:process signull; ') ######################################## ## ## Execute pppd in the pppd domain. ## ## ## ## Domain allowed to transition. ## ## # interface(`ppp_domtrans',` gen_require(` type pppd_t, pppd_exec_t; ') corecmd_search_bin($1) domtrans_pattern($1, pppd_exec_t, pppd_t) ') ######################################## ## ## Conditionally execute pppd on ## behalf of a user or staff type. ## ## ## ## Domain allowed to transition. ## ## ## ## ## Role allowed access. ## ## ## # interface(`ppp_run_cond',` gen_require(` attribute_role pppd_roles; ') roleattribute $2 pppd_roles; tunable_policy(`pppd_for_user',` ppp_domtrans($1) ') ') ######################################## ## ## Unconditionally execute ppp daemon ## on behalf of a user or staff type. ## ## ## ## Domain allowed to transition. ## ## ## ## ## Role allowed access. ## ## ## # interface(`ppp_run',` gen_require(` attribute_role pppd_roles; ') ppp_domtrans($1) roleattribute $2 pppd_roles; ') ######################################## ## ## Execute domain in the caller domain. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_exec',` gen_require(` type pppd_exec_t; ') corecmd_search_bin($1) can_exec($1, pppd_exec_t) ') ######################################## ## ## Read ppp configuration files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_config',` gen_require(` type pppd_etc_t; ') files_search_etc($1) read_files_pattern($1, pppd_etc_t, pppd_etc_t) ') ######################################## ## ## Read ppp writable configuration content. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_rw_config',` gen_require(` type pppd_etc_t, pppd_etc_rw_t; ') files_search_etc($1) allow $1 { pppd_etc_t pppd_etc_rw_t }:dir list_dir_perms; allow $1 pppd_etc_rw_t:file read_file_perms; allow $1 { pppd_etc_t pppd_etc_rw_t }:lnk_file read_lnk_file_perms; ') ######################################## ## ## Read ppp secret files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_secrets',` gen_require(` type pppd_etc_t, pppd_secret_t; ') files_search_etc($1) allow $1 pppd_etc_t:dir list_dir_perms; allow $1 pppd_secret_t:file read_file_perms; allow $1 pppd_etc_t:lnk_file read_lnk_file_perms; ') ######################################## ## ## Read ppp pid files. (Deprecated) ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_pid_files',` refpolicywarn(`$0($*) has been deprecated, please use ppp_read_runtime_files() instead.') ppp_read_runtime_files($1) ') ######################################## ## ## Create, read, write, and delete ## ppp pid files. (Deprecated) ## ## ## ## Domain allowed access. ## ## # interface(`ppp_manage_pid_files',` refpolicywarn(`$0($*) has been deprecated, please use ppp_manage_runtime_files() instead.') ppp_manage_runtime_files($1) ') ######################################## ## ## Create specified pppd pid objects ## with a type transition. (Deprecated) ## ## ## ## Domain allowed access. ## ## ## ## ## Class of the object being created. ## ## ## ## ## The name of the object being created. ## ## # interface(`ppp_pid_filetrans',` refpolicywarn(`$0($*) has been deprecated, please use ppp_runtime_filetrans() instead.') ppp_runtime_filetrans($1, $2, $3) ') ######################################## ## ## Read ppp runtime files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_runtime_files',` gen_require(` type pppd_runtime_t; ') files_search_pids($1) allow $1 pppd_runtime_t:file read_file_perms; ') ######################################## ## ## Create, read, write, and delete ## ppp runtime files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_manage_runtime_files',` gen_require(` type pppd_runtime_t; ') files_search_pids($1) allow $1 pppd_runtime_t:file manage_file_perms; ') ######################################## ## ## Create specified pppd runtime objects ## with a type transition. ## ## ## ## Domain allowed access. ## ## ## ## ## Class of the object being created. ## ## ## ## ## The name of the object being created. ## ## # interface(`ppp_runtime_filetrans',` gen_require(` type pppd_runtime_t; ') files_pid_filetrans($1, pppd_runtime_t, $2, $3) ') ######################################## ## ## Execute pppd init script in ## the initrc domain. ## ## ## ## Domain allowed to transition. ## ## # interface(`ppp_initrc_domtrans',` gen_require(` type pppd_initrc_exec_t; ') init_labeled_script_domtrans($1, pppd_initrc_exec_t) ') ######################################## ## ## All of the rules required to ## administrate an ppp environment. ## ## ## ## Domain allowed access. ## ## ## ## ## Role allowed access. ## ## ## # interface(`ppp_admin',` gen_require(` type pppd_t, pppd_tmp_t, pppd_log_t, pppd_lock_t; type pppd_etc_t, pppd_secret_t, pppd_etc_rw_t; type pppd_runtime_t, pppd_initrc_exec_t; type pptp_t, pptp_log_t, pptp_runtime_t; ') allow $1 { pptp_t pppd_t }:process { ptrace signal_perms }; ps_process_pattern($1, { pptp_t pppd_t }) init_startstop_service($1, $2, pppd_t, pppd_initrc_exec_t) files_list_tmp($1) admin_pattern($1, pppd_tmp_t) logging_list_logs($1) admin_pattern($1, { pptp_log_t pppd_log_t }) files_list_locks($1) admin_pattern($1, pppd_lock_t) files_list_etc($1) admin_pattern($1, { pppd_etc_rw_t pppd_secret_t pppd_etc_t }) files_list_pids($1) admin_pattern($1, { pptp_runtime_t pppd_runtime_t }) ')