## 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 a SIGCHLD signal to PPP. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_sigchld',` gen_require(` type pppd_t; ') allow $1 pppd_t:process sigchld; ') ######################################## ## ## Send ppp a kill signal ## ## ## ## Domain allowed access. ## ## # interface(`ppp_kill',` gen_require(` type pppd_t; ') allow $1 pppd_t:process sigkill; ') ######################################## ## ## Send a generic signal to PPP. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_signal',` gen_require(` type pppd_t; ') allow $1 pppd_t:process signal; ') ######################################## ## ## Send a generic signull to PPP. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_signull',` gen_require(` type pppd_t; ') allow $1 pppd_t:process signull; ') ######################################## ## ## Execute domain in the ppp 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 ppp daemon on behalf of a user or staff type. ## ## ## ## Domain allowed to transition. ## ## ## ## ## The role to allow the ppp domain. ## ## ## # 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. ## ## ## ## ## The role to allow the ppp domain. ## ## ## # interface(`ppp_run',` gen_require(` attribute_role pppd_roles; ') ppp_domtrans($1) roleattribute $2 pppd_roles; ') ######################################## ## ## Execute domain in the ppp caller. ## ## ## ## 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; ') read_files_pattern($1, pppd_etc_t, pppd_etc_t) files_search_etc($1) ') ######################################## ## ## Read PPP-writable configuration files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_rw_config',` gen_require(` type pppd_etc_t, pppd_etc_rw_t; ') allow $1 pppd_etc_t:dir list_dir_perms; allow $1 pppd_etc_rw_t:file read_file_perms; files_search_etc($1) ') ######################################## ## ## Read PPP secrets. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_secrets',` gen_require(` type pppd_etc_t, pppd_secret_t; ') allow $1 pppd_etc_t:dir list_dir_perms; allow $1 pppd_secret_t:file read_file_perms; files_search_etc($1) ') ######################################## ## ## Read PPP pid files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_read_pid_files',` gen_require(` type pppd_var_run_t; ') files_search_pids($1) read_files_pattern($1, pppd_var_run_t, pppd_var_run_t) ') ######################################## ## ## Create, read, write, and delete PPP pid files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_manage_pid_files',` gen_require(` type pppd_var_run_t; ') files_search_pids($1) allow $1 pppd_var_run_t:file manage_file_perms; ') ######################################## ## ## Create, read, write, and delete PPP pid files. ## ## ## ## Domain allowed access. ## ## # interface(`ppp_pid_filetrans',` gen_require(` type pppd_var_run_t; ') files_pid_filetrans($1, pppd_var_run_t, file) ') ######################################## ## ## Execute ppp server in the ntpd 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) ') ######################################## ## ## Execute pppd server in the pppd domain. ## ## ## ## Domain allowed to transition. ## ## # interface(`ppp_systemctl',` gen_require(` type pppd_unit_file_t; type pppd_t; ') systemd_exec_systemctl($1) allow $1 pppd_unit_file_t:file read_file_perms; allow $1 pppd_unit_file_t:service manage_service_perms; ps_process_pattern($1, pppd_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_var_run_t; type pptp_t, pptp_log_t, pptp_var_run_t; type pppd_initrc_exec_t, pppd_etc_rw_t; type pppd_unit_file_t; ') allow $1 pppd_t:process signal_perms; ps_process_pattern($1, pppd_t) tunable_policy(`deny_ptrace',`',` allow $1 pppd_t:process ptrace; allow $1 pptp_t:process ptrace; ') allow $1 pptp_t:process signal_perms; ps_process_pattern($1, pptp_t) ppp_initrc_domtrans($1) domain_system_change_exemption($1) role_transition $2 pppd_initrc_exec_t system_r; allow $2 system_r; files_list_tmp($1) admin_pattern($1, pppd_tmp_t) logging_list_logs($1) admin_pattern($1, pppd_log_t) files_list_locks($1) admin_pattern($1, pppd_lock_t) files_list_etc($1) admin_pattern($1, pppd_etc_t) admin_pattern($1, pppd_etc_rw_t) admin_pattern($1, pppd_secret_t) files_list_pids($1) admin_pattern($1, pppd_var_run_t) admin_pattern($1, pptp_log_t) admin_pattern($1, pptp_var_run_t) ppp_systemctl($1) admin_pattern($1, pppd_unit_file_t) allow $1 pppd_unit_file_t:service all_service_perms; ')