diff options
author | Jason Zaman <jason@perfinion.com> | 2015-07-16 17:09:44 +0400 |
---|---|---|
committer | Jason Zaman <jason@perfinion.com> | 2015-07-31 00:41:33 +0800 |
commit | 668db9970fcfe4c20ba9619272799c3dd258fce0 (patch) | |
tree | 8e4821291c4f8bd27c4c0cd7ae2bd823c0aa0f53 | |
parent | add new cron_admin interface to sysadm (diff) | |
download | hardened-refpolicy-668db9970fcfe4c20ba9619272799c3dd258fce0.tar.gz hardened-refpolicy-668db9970fcfe4c20ba9619272799c3dd258fce0.tar.bz2 hardened-refpolicy-668db9970fcfe4c20ba9619272799c3dd258fce0.zip |
Introduce cron_admin interface
-rw-r--r-- | policy/modules/contrib/cron.if | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/policy/modules/contrib/cron.if b/policy/modules/contrib/cron.if index 868d89f4..39258118 100644 --- a/policy/modules/contrib/cron.if +++ b/policy/modules/contrib/cron.if @@ -835,3 +835,56 @@ interface(`cron_dontaudit_write_system_job_tmp_files',` dontaudit $1 system_cronjob_tmp_t:file write_file_perms; ') + +######################################## +## <summary> +## All of the rules required to +## administrate a cron environment. +## </summary> +## <param name="domain"> +## <summary> +## Domain allowed access. +## </summary> +## </param> +## <param name="role"> +## <summary> +## Role allowed access. +## </summary> +## </param> +## <rolecap/> +# +interface(`cron_admin',` + gen_require(` + type crond_t, cronjob_t, crond_initrc_exec_t; + type cron_var_lib_t, system_cronjob_var_lib_t; + type crond_tmp_t, admin_crontab_tmp_t; + type crontab_tmp_t, system_cronjob_tmp_t; + type cron_var_run_t, system_cronjob_var_run_t, crond_var_run_t; + type cron_log_t, system_cronjob_lock_t, user_cron_spool_log_t; + attribute cron_spool_type; + ') + + allow $1 { crond_t cronjob_t }:process { ptrace signal_perms }; + ps_process_pattern($1, { crond_t cronjob_t }) + + init_startstop_service($1, $2, crond_t, crond_initrc_exec_t) + + files_search_var_lib($1) + admin_pattern($1, { cron_var_lib_t system_cronjob_var_lib_t }) + + files_search_tmp($1) + admin_pattern($1, { crond_tmp_t admin_crontab_tmp_t }) + admin_pattern($1, { crontab_tmp_t system_cronjob_tmp_t }) + + files_search_pids($1) + admin_pattern($1, { cron_var_run_t crond_var_run_t system_cronjob_var_run_t }) + + files_search_locks($1) + admin_pattern($1, system_cronjob_lock_t) + + logging_search_logs($1) + admin_pattern($1, { cron_log_t user_cron_spool_log_t }) + + files_search_spool($1) + admin_pattern($1, cron_spool_type) +') |