1ec3d1a
## <summary>Software for reliable, scalable, distributed computing.</summary>
1ec3d1a
1ec3d1a
#######################################
1ec3d1a
## <summary>
1ec3d1a
##	The template to define a hadoop domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain_prefix">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain prefix to be used.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
template(`hadoop_domain_template',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute hadoop_domain;
1ec3d1a
		type hadoop_log_t, hadoop_var_lib_t, hadoop_var_run_t;
1ec3d1a
		type hadoop_exec_t, hadoop_hsperfdata_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	########################################
1ec3d1a
	#
1ec3d1a
	# Shared declarations.
1ec3d1a
	#
1ec3d1a
1ec3d1a
	type hadoop_$1_t, hadoop_domain;
1ec3d1a
	domain_type(hadoop_$1_t)
1ec3d1a
	domain_entry_file(hadoop_$1_t, hadoop_exec_t)
1ec3d1a
	role system_r types hadoop_$1_t;
1ec3d1a
1ec3d1a
	type hadoop_$1_initrc_t;
1ec3d1a
	type hadoop_$1_initrc_exec_t;
1ec3d1a
	init_script_domain(hadoop_$1_initrc_t, hadoop_$1_initrc_exec_t)
1ec3d1a
	role system_r types hadoop_$1_initrc_t;
1ec3d1a
1ec3d1a
	type hadoop_$1_initrc_var_run_t;
1ec3d1a
	files_pid_file(hadoop_$1_initrc_var_run_t)
1ec3d1a
1ec3d1a
	type hadoop_$1_lock_t;
1ec3d1a
	files_lock_file(hadoop_$1_lock_t)
1ec3d1a
1ec3d1a
	type hadoop_$1_log_t;
1ec3d1a
	logging_log_file(hadoop_$1_log_t)
1ec3d1a
1ec3d1a
	type hadoop_$1_tmp_t;
1ec3d1a
	files_tmp_file(hadoop_$1_tmp_t)
1ec3d1a
1ec3d1a
	type hadoop_$1_var_lib_t;
1ec3d1a
	files_type(hadoop_$1_var_lib_t)
1ec3d1a
1ec3d1a
	####################################
1ec3d1a
	#
1ec3d1a
	# Shared hadoop_$1 policy.
1ec3d1a
	#
1ec3d1a
1ec3d1a
	allow hadoop_$1_t self:capability { chown kill setgid setuid };
1ec3d1a
	allow hadoop_$1_t self:process { execmem getsched setsched sigkill signal };
1ec3d1a
	allow hadoop_$1_t self:key search;
1ec3d1a
	allow hadoop_$1_t self:fifo_file rw_fifo_file_perms;
1ec3d1a
	allow hadoop_$1_t self:unix_dgram_socket create_socket_perms;
1ec3d1a
	allow hadoop_$1_t self:tcp_socket create_stream_socket_perms;
1ec3d1a
	allow hadoop_$1_t self:udp_socket create_socket_perms;
1ec3d1a
	dontaudit hadoop_$1_t self:netlink_route_socket rw_netlink_socket_perms;
1ec3d1a
1ec3d1a
	allow hadoop_$1_t hadoop_domain:process signull;
1ec3d1a
1ec3d1a
	manage_files_pattern(hadoop_$1_t, hadoop_$1_log_t, hadoop_$1_log_t)
1ec3d1a
	filetrans_pattern(hadoop_$1_t, hadoop_log_t, hadoop_$1_log_t, { dir file })
1ec3d1a
	logging_search_logs(hadoop_$1_t)
1ec3d1a
1ec3d1a
	manage_dirs_pattern(hadoop_$1_t, hadoop_$1_var_lib_t, hadoop_$1_var_lib_t)
1ec3d1a
	manage_files_pattern(hadoop_$1_t, hadoop_$1_var_lib_t, hadoop_$1_var_lib_t)
1ec3d1a
	filetrans_pattern(hadoop_$1_t, hadoop_var_lib_t, hadoop_$1_var_lib_t, file)
1ec3d1a
	files_search_var_lib(hadoop_$1_t)
1ec3d1a
1ec3d1a
	manage_files_pattern(hadoop_$1_t, hadoop_$1_initrc_var_run_t, hadoop_$1_initrc_var_run_t)
1ec3d1a
	filetrans_pattern(hadoop_$1_t, hadoop_var_run_t, hadoop_$1_initrc_var_run_t, file)
1ec3d1a
	files_search_pids(hadoop_$1_t)
1ec3d1a
1ec3d1a
	allow hadoop_$1_t hadoop_hsperfdata_t:dir manage_dir_perms;
1ec3d1a
	manage_files_pattern(hadoop_$1_t, hadoop_$1_tmp_t, hadoop_$1_tmp_t)
1ec3d1a
	filetrans_pattern(hadoop_$1_t, hadoop_hsperfdata_t, hadoop_$1_tmp_t, file)
1ec3d1a
	files_tmp_filetrans(hadoop_$1_t, hadoop_hsperfdata_t, dir)
1ec3d1a
1ec3d1a
	kernel_read_kernel_sysctls(hadoop_$1_t)
1ec3d1a
	kernel_read_sysctl(hadoop_$1_t)
1ec3d1a
	kernel_read_network_state(hadoop_$1_t)
1ec3d1a
	kernel_read_system_state(hadoop_$1_t)
1ec3d1a
1ec3d1a
	corecmd_exec_bin(hadoop_$1_t)
1ec3d1a
	corecmd_exec_shell(hadoop_$1_t)
1ec3d1a
1ec3d1a
	corenet_all_recvfrom_netlabel(hadoop_$1_t)
Chris PeBenito 9401ae1
	corenet_tcp_bind_all_nodes(hadoop_$1_t)
1ec3d1a
	corenet_tcp_sendrecv_generic_if(hadoop_$1_t)
1ec3d1a
	corenet_udp_sendrecv_generic_if(hadoop_$1_t)
1ec3d1a
	corenet_tcp_sendrecv_generic_node(hadoop_$1_t)
1ec3d1a
	corenet_udp_sendrecv_generic_node(hadoop_$1_t)
1ec3d1a
	corenet_tcp_sendrecv_all_ports(hadoop_$1_t)
1ec3d1a
	corenet_udp_bind_generic_node(hadoop_$1_t)
1ec3d1a
	# Hadoop uses high ordered random ports for services
1ec3d1a
	# If permanent ports are chosen, remove line below and lock down
1ec3d1a
	corenet_tcp_connect_generic_port(hadoop_$1_t)
1ec3d1a
1ec3d1a
	dev_read_rand(hadoop_$1_t)
1ec3d1a
	dev_read_urand(hadoop_$1_t)
1ec3d1a
	dev_read_sysfs(hadoop_$1_t)
1ec3d1a
1ec3d1a
	files_read_etc_files(hadoop_$1_t)
1ec3d1a
1ec3d1a
	auth_domtrans_chkpwd(hadoop_$1_t)
1ec3d1a
1ec3d1a
	hadoop_match_lan_spd(hadoop_$1_t)
1ec3d1a
1ec3d1a
	init_read_utmp(hadoop_$1_t)
1ec3d1a
	init_use_fds(hadoop_$1_t)
1ec3d1a
	init_use_script_fds(hadoop_$1_t)
1ec3d1a
	init_use_script_ptys(hadoop_$1_t)
1ec3d1a
1ec3d1a
	logging_send_audit_msgs(hadoop_$1_t)
1ec3d1a
	logging_send_syslog_msg(hadoop_$1_t)
1ec3d1a
1ec3d1a
	miscfiles_read_localization(hadoop_$1_t)
1ec3d1a
1ec3d1a
	sysnet_read_config(hadoop_$1_t)
1ec3d1a
1ec3d1a
	hadoop_exec_config(hadoop_$1_t)
1ec3d1a
Chris PeBenito 9401ae1
	java_exec(hadoop_$1_t)
1ec3d1a
1ec3d1a
	kerberos_use(hadoop_$1_t)
1ec3d1a
1ec3d1a
	su_exec(hadoop_$1_t)
1ec3d1a
Chris PeBenito 9401ae1
	optional_policy(`
Chris PeBenito 9401ae1
		nscd_socket_use(hadoop_$1_t)
Chris PeBenito 9401ae1
	')
Chris PeBenito 9401ae1
1ec3d1a
	####################################
1ec3d1a
	#
1ec3d1a
	# Shared hadoop_$1 initrc policy.
1ec3d1a
	#
1ec3d1a
1ec3d1a
	allow hadoop_$1_initrc_t self:capability { setuid setgid };
1ec3d1a
	dontaudit hadoop_$1_initrc_t self:capability sys_tty_config;
1ec3d1a
	allow hadoop_$1_initrc_t self:process setsched;
1ec3d1a
	allow hadoop_$1_initrc_t self:fifo_file rw_fifo_file_perms;
1ec3d1a
1ec3d1a
	allow hadoop_$1_initrc_t hadoop_$1_t:process { signal signull };
1ec3d1a
1ec3d1a
	domtrans_pattern(hadoop_$1_initrc_t, hadoop_exec_t, hadoop_$1_t)
1ec3d1a
1ec3d1a
	manage_files_pattern(hadoop_$1_initrc_t, hadoop_$1_lock_t, hadoop_$1_lock_t)
1ec3d1a
	files_lock_filetrans(hadoop_$1_initrc_t, hadoop_$1_lock_t, file)
1ec3d1a
	files_search_locks(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	manage_files_pattern(hadoop_$1_initrc_t, hadoop_$1_initrc_var_run_t, hadoop_$1_initrc_var_run_t)
1ec3d1a
	filetrans_pattern(hadoop_$1_initrc_t, hadoop_var_run_t, hadoop_$1_initrc_var_run_t, file)
1ec3d1a
	files_search_pids(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	manage_files_pattern(hadoop_$1_initrc_t, hadoop_$1_log_t, hadoop_$1_log_t)
1ec3d1a
	filetrans_pattern(hadoop_$1_initrc_t, hadoop_log_t, hadoop_$1_log_t, { dir file })
1ec3d1a
	logging_search_logs(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	manage_dirs_pattern(hadoop_$1_initrc_t, hadoop_var_run_t, hadoop_var_run_t)
1ec3d1a
	manage_files_pattern(hadoop_$1_initrc_t, hadoop_var_run_t, hadoop_var_run_t)
1ec3d1a
1ec3d1a
	kernel_read_kernel_sysctls(hadoop_$1_initrc_t)
1ec3d1a
	kernel_read_sysctl(hadoop_$1_initrc_t)
1ec3d1a
	kernel_read_system_state(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	corecmd_exec_bin(hadoop_$1_initrc_t)
1ec3d1a
	corecmd_exec_shell(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	files_read_etc_files(hadoop_$1_initrc_t)
1ec3d1a
	files_read_usr_files(hadoop_$1_initrc_t)
1ec3d1a
Chris PeBenito 9401ae1
	consoletype_exec(hadoop_$1_initrc_t)
Chris PeBenito 9401ae1
1ec3d1a
	fs_getattr_xattr_fs(hadoop_$1_initrc_t)
1ec3d1a
	fs_search_cgroup_dirs(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	term_use_generic_ptys(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	hadoop_exec_config(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	init_rw_utmp(hadoop_$1_initrc_t)
1ec3d1a
	init_use_fds(hadoop_$1_initrc_t)
1ec3d1a
	init_use_script_ptys(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	logging_send_syslog_msg(hadoop_$1_initrc_t)
1ec3d1a
	logging_send_audit_msgs(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	miscfiles_read_localization(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	userdom_dontaudit_search_user_home_dirs(hadoop_$1_initrc_t)
1ec3d1a
1ec3d1a
	optional_policy(`
Chris PeBenito 9401ae1
		nscd_socket_use(hadoop_$1_initrc_t)
Chris PeBenito 9401ae1
	')
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Role access for hadoop.
1ec3d1a
## </summary>
1ec3d1a
## <param name="role">
1ec3d1a
##	<summary>
1ec3d1a
##	Role allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <rolecap/>
1ec3d1a
#
1ec3d1a
interface(`hadoop_role',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	hadoop_domtrans($2)
1ec3d1a
	role $1 types hadoop_t;
1ec3d1a
1ec3d1a
	allow $2 hadoop_t:process signal_perms;
1ec3d1a
	ps_process_pattern($2, hadoop_t)
1ec3d1a
	tunable_policy(`deny_ptrace',`',`
1ec3d1a
		allow $2 hadoop_t:process ptrace;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	hadoop_domtrans_zookeeper_client($2)
1ec3d1a
	role $1 types zookeeper_t;
1ec3d1a
1ec3d1a
	allow $2 zookeeper_t:process signal_perms;
1ec3d1a
	ps_process_pattern($2, zookeeper_t)
1ec3d1a
	tunable_policy(`deny_ptrace',`',`
1ec3d1a
		allow $2 zookeeper_t:process ptrace;
1ec3d1a
	')
1ec3d1a
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute hadoop in the
1ec3d1a
##	hadoop domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_domtrans',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_t, hadoop_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, hadoop_exec_t, hadoop_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom hadoop_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 hadoop_t:peer recv;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute zookeeper client in the
1ec3d1a
##	zookeeper client domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_domtrans_zookeeper_client',`
1ec3d1a
	gen_require(`
1ec3d1a
		type zookeeper_t, zookeeper_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	corecmd_search_bin($1)
1ec3d1a
	domtrans_pattern($1, zookeeper_exec_t, zookeeper_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom zookeeper_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom_zookeeper_client',`
1ec3d1a
	gen_require(`
1ec3d1a
		type zookeeper_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 zookeeper_t:peer recv;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute zookeeper server in the
1ec3d1a
##	zookeeper server domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_domtrans_zookeeper_server',`
1ec3d1a
	gen_require(`
1ec3d1a
		type zookeeper_server_t, zookeeper_server_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	corecmd_search_bin($1)
1ec3d1a
	domtrans_pattern($1, zookeeper_server_exec_t, zookeeper_server_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom zookeeper_server_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom_zookeeper_server',`
1ec3d1a
	gen_require(`
1ec3d1a
		type zookeeper_server_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 zookeeper_server_t:peer recv;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute zookeeper server in the
1ec3d1a
##	zookeeper domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_initrc_domtrans_zookeeper_server',`
1ec3d1a
	gen_require(`
1ec3d1a
		type zookeeper_server_initrc_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	init_labeled_script_domtrans($1, zookeeper_server_initrc_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom hadoop_datanode_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom_datanode',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_datanode_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 hadoop_datanode_t:peer recv;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to read
1ec3d1a
##	hadoop_etc_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing read permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_read_config',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_etc_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	read_files_pattern($1, hadoop_etc_t, hadoop_etc_t)
1ec3d1a
	read_lnk_files_pattern($1, hadoop_etc_t, hadoop_etc_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	execute hadoop_etc_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing read and execute
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_exec_config',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_etc_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	hadoop_read_config($1)
1ec3d1a
	allow $1 hadoop_etc_t:file exec_file_perms;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom hadoop_jobtracker_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom_jobtracker',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_jobtracker_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 hadoop_jobtracker_t:peer recv;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	polmatch on hadoop_lan_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing polmatch
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_match_lan_spd',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_lan_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 hadoop_lan_t:association polmatch;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom hadoop_namenode_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom_namenode',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_namenode_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 hadoop_namenode_t:peer recv;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom hadoop_secondarynamenode_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom_secondarynamenode',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_secondarynamenode_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 hadoop_secondarynamenode_t:peer recv;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Give permission to a domain to
1ec3d1a
##	recvfrom hadoop_tasktracker_t
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain needing recvfrom
1ec3d1a
##	permission
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`hadoop_recvfrom_tasktracker',`
1ec3d1a
	gen_require(`
1ec3d1a
		type hadoop_tasktracker_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 hadoop_tasktracker_t:peer recv;
1ec3d1a
')