commit:     8a2e9526fe60459f6ce9b81530da19d86bae4ca4
Author:     Jason Zaman <jason <AT> perfinion <DOT> com>
AuthorDate: Mon Jun  8 20:38:21 2015 +0000
Commit:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
CommitDate: Tue Jun  9 13:06:34 2015 +0000
URL:        
https://gitweb.gentoo.org/proj/hardened-refpolicy.git/commit/?id=8a2e9526

Introduce iptables_admin

 policy/modules/roles/sysadm.te    |  1 +
 policy/modules/system/iptables.if | 39 +++++++++++++++++++++++++++++++++++++++
 2 files changed, 40 insertions(+)

diff --git a/policy/modules/roles/sysadm.te b/policy/modules/roles/sysadm.te
index 4cfb014..9169215 100644
--- a/policy/modules/roles/sysadm.te
+++ b/policy/modules/roles/sysadm.te
@@ -178,6 +178,7 @@ optional_policy(`
 ')
 
 optional_policy(`
+       iptables_admin(sysadm_t, sysadm_r)
        iptables_run(sysadm_t, sysadm_r)
 ')
 

diff --git a/policy/modules/system/iptables.if 
b/policy/modules/system/iptables.if
index c42fbc3..26ce647 100644
--- a/policy/modules/system/iptables.if
+++ b/policy/modules/system/iptables.if
@@ -163,3 +163,42 @@ interface(`iptables_manage_config',`
        files_search_etc($1)
        manage_files_pattern($1, iptables_conf_t, iptables_conf_t)
 ')
+
+########################################
+## <summary>
+##     All of the rules required to
+##     administrate an iptables
+##     environment.
+## </summary>
+## <param name="domain">
+##     <summary>
+##     Domain allowed access.
+##     </summary>
+## </param>
+## <param name="role">
+##     <summary>
+##     Role allowed access.
+##     </summary>
+## </param>
+## <rolecap/>
+#
+interface(`iptables_admin',`
+       gen_require(`
+               type iptables_t, iptables_initrc_exec_t, iptables_conf_t;
+               type iptables_tmp_t, iptables_var_run_t;
+       ')
+
+       allow $1 iptables_t:process { ptrace signal_perms };
+       ps_process_pattern($1, iptables_t)
+
+       init_startstop_service($1, $2, iptables_t, iptables_initrc_exec_t)
+
+       files_list_etc($1)
+       admin_pattern($1, iptables_conf_t)
+
+       files_list_tmp($1)
+       admin_pattern($1, iptables_tmp_t)
+
+       files_list_pids($1)
+       admin_pattern($1, iptables_var_run_t)
+')

Reply via email to