1ec3d1a
policy_module(collectd, 1.0.0)
1ec3d1a
1ec3d1a
########################################
1ec3d1a
#
1ec3d1a
# Declarations
1ec3d1a
#
1ec3d1a
1ec3d1a
## <desc>
1ec3d1a
##  

1ec3d1a
##  Allow collectd to connect to the
1ec3d1a
##  network using TCP.
1ec3d1a
##  

1ec3d1a
## </desc>
1ec3d1a
gen_tunable(collectd_can_network_connect, false)
1ec3d1a
1ec3d1a
type collectd_t;
1ec3d1a
type collectd_exec_t;
1ec3d1a
init_daemon_domain(collectd_t, collectd_exec_t)
1ec3d1a
1ec3d1a
type collectd_initrc_exec_t;
1ec3d1a
init_script_file(collectd_initrc_exec_t)
1ec3d1a
1ec3d1a
type collectd_var_lib_t;
1ec3d1a
files_type(collectd_var_lib_t)
1ec3d1a
1ec3d1a
type collectd_var_run_t;
1ec3d1a
files_pid_file(collectd_var_run_t)
1ec3d1a
1ec3d1a
type collectd_unit_file_t;
1ec3d1a
systemd_unit_file(collectd_unit_file_t)
1ec3d1a
1ec3d1a
########################################
1ec3d1a
#
1ec3d1a
# collectd local policy
1ec3d1a
#
1ec3d1a
d05c17b
allow collectd_t self:capability { ipc_lock sys_nice };
d05c17b
allow collectd_t self:process { getsched setsched signal fork };
1ec3d1a
1ec3d1a
allow collectd_t self:fifo_file rw_fifo_file_perms;
1ec3d1a
allow collectd_t self:packet_socket create_socket_perms;
1ec3d1a
allow collectd_t self:unix_stream_socket create_stream_socket_perms;
1ec3d1a
1ec3d1a
manage_dirs_pattern(collectd_t, collectd_var_lib_t, collectd_var_lib_t)
1ec3d1a
manage_files_pattern(collectd_t, collectd_var_lib_t, collectd_var_lib_t)
1ec3d1a
files_var_lib_filetrans(collectd_t, collectd_var_lib_t, { dir file })
1ec3d1a
1ec3d1a
manage_dirs_pattern(collectd_t, collectd_var_run_t, collectd_var_run_t)
1ec3d1a
manage_files_pattern(collectd_t, collectd_var_run_t, collectd_var_run_t)
1ec3d1a
files_pid_filetrans(collectd_t, collectd_var_run_t, { dir file })
1ec3d1a
1ec3d1a
domain_use_interactive_fds(collectd_t)
1ec3d1a
1ec3d1a
kernel_read_network_state(collectd_t)
1ec3d1a
kernel_read_net_sysctls(collectd_t)
1ec3d1a
kernel_read_system_state(collectd_t)
1ec3d1a
1ec3d1a
dev_read_sysfs(collectd_t)
1ec3d1a
dev_read_urand(collectd_t)
1ec3d1a
dev_read_rand(collectd_t)
1ec3d1a
1ec3d1a
files_getattr_all_dirs(collectd_t)
1ec3d1a
files_read_etc_files(collectd_t)
1ec3d1a
files_read_usr_files(collectd_t)
1ec3d1a
1ec3d1a
fs_getattr_all_fs(collectd_t)
1ec3d1a
1ec3d1a
logging_send_syslog_msg(collectd_t)
1ec3d1a
1ec3d1a
sysnet_dns_name_resolve(collectd_t)
1ec3d1a
1ec3d1a
tunable_policy(`collectd_can_network_connect',`
1ec3d1a
    corenet_tcp_connect_all_ports(collectd_t)
1ec3d1a
    corenet_tcp_sendrecv_all_ports(collectd_t)
1ec3d1a
    corenet_sendrecv_all_client_packets(collectd_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
optional_policy(`
1ec3d1a
	apache_content_template(collectd)
1ec3d1a
1ec3d1a
	files_search_var_lib(httpd_collectd_script_t)	
1ec3d1a
	read_files_pattern(httpd_collectd_script_t, collectd_var_lib_t, collectd_var_lib_t)
1ec3d1a
	list_dirs_pattern(httpd_collectd_script_t, collectd_var_lib_t, collectd_var_lib_t)
1ec3d1a
	miscfiles_setattr_fonts_cache_dirs(httpd_collectd_script_t)
1ec3d1a
')
1ec3d1a
34105c5
optional_policy(`
34105c5
	virt_read_config(collectd_t)
34105c5
')