b43f464
## <summary>Postfix email server</summary>
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Postfix stub interface.  No access allowed.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain" unused="true">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_stub',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_t;
1ec3d1a
	')
1ec3d1a
')
1ec3d1a
b43f464
########################################
1ec3d1a
## <summary>
b43f464
##	Creates types and rules for a basic
b43f464
##	postfix process domain.
1ec3d1a
## </summary>
b43f464
## <param name="prefix">
1ec3d1a
##	<summary>
b43f464
##	Prefix for the domain.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
template(`postfix_domain_template',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_domain;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	type postfix_$1_t, postfix_domain;
1ec3d1a
	type postfix_$1_exec_t;
1ec3d1a
	domain_type(postfix_$1_t)
1ec3d1a
	domain_entry_file(postfix_$1_t, postfix_$1_exec_t)
1ec3d1a
	role system_r types postfix_$1_t;
1ec3d1a
1bafb67
	kernel_read_system_state(postfix_$1_t)
1bafb67
1ec3d1a
	auth_use_nsswitch(postfix_$1_t)
1ec3d1a
05b4f84
	logging_send_syslog_msg(postfix_$1_t)
05b4f84
1ec3d1a
	can_exec(postfix_$1_t, postfix_$1_exec_t)
1ec3d1a
')
1ec3d1a
b43f464
########################################
1ec3d1a
## <summary>
b43f464
##	Creates a postfix server process domain.
1ec3d1a
## </summary>
b43f464
## <param name="prefix">
1ec3d1a
##	<summary>
b43f464
##	Prefix of the domain.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
template(`postfix_server_domain_template',`
1ec3d1a
	postfix_domain_template($1)
1ec3d1a
b43f464
	type postfix_$1_tmp_t;
1ec3d1a
	files_tmp_file(postfix_$1_tmp_t)
1ec3d1a
1ec3d1a
	allow postfix_$1_t self:capability { setuid setgid sys_chroot dac_override };
1ec3d1a
	allow postfix_$1_t postfix_master_t:unix_stream_socket { connectto rw_stream_socket_perms };
1ec3d1a
	allow postfix_$1_t self:tcp_socket create_socket_perms;
1ec3d1a
	allow postfix_$1_t self:udp_socket create_socket_perms;
1ec3d1a
1ec3d1a
	manage_dirs_pattern(postfix_$1_t, postfix_$1_tmp_t, postfix_$1_tmp_t)
1ec3d1a
	manage_files_pattern(postfix_$1_t, postfix_$1_tmp_t, postfix_$1_tmp_t)
1ec3d1a
	files_tmp_filetrans(postfix_$1_t, postfix_$1_tmp_t, { file dir })
1ec3d1a
1ec3d1a
	domtrans_pattern(postfix_master_t, postfix_$1_exec_t, postfix_$1_t)
1ec3d1a
1ec3d1a
	corenet_all_recvfrom_netlabel(postfix_$1_t)
1ec3d1a
	corenet_tcp_sendrecv_generic_if(postfix_$1_t)
1ec3d1a
	corenet_udp_sendrecv_generic_if(postfix_$1_t)
1ec3d1a
	corenet_tcp_sendrecv_generic_node(postfix_$1_t)
1ec3d1a
	corenet_udp_sendrecv_generic_node(postfix_$1_t)
1ec3d1a
	corenet_tcp_sendrecv_all_ports(postfix_$1_t)
1ec3d1a
	corenet_udp_sendrecv_all_ports(postfix_$1_t)
1ec3d1a
	corenet_tcp_bind_generic_node(postfix_$1_t)
1ec3d1a
	corenet_udp_bind_generic_node(postfix_$1_t)
1ec3d1a
	corenet_tcp_connect_all_ports(postfix_$1_t)
1ec3d1a
	corenet_sendrecv_all_client_packets(postfix_$1_t)
1ec3d1a
')
1ec3d1a
b43f464
########################################
1ec3d1a
## <summary>
b43f464
##	Creates a process domain for programs
b43f464
##	that are ran by users.
1ec3d1a
## </summary>
b43f464
## <param name="prefix">
1ec3d1a
##	<summary>
b43f464
##	Prefix of the domain.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
template(`postfix_user_domain_template',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_user_domains, postfix_user_domtrans;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	postfix_domain_template($1)
1ec3d1a
1ec3d1a
	typeattribute postfix_$1_t postfix_user_domains;
1ec3d1a
1ec3d1a
	allow postfix_$1_t self:capability dac_override;
1ec3d1a
1ec3d1a
	domtrans_pattern(postfix_user_domtrans, postfix_$1_exec_t, postfix_$1_t)
1ec3d1a
1ec3d1a
	domain_use_interactive_fds(postfix_$1_t)
1ec3d1a
1ec3d1a
	application_domain(postfix_$1_t, postfix_$1_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Read postfix configuration files.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <rolecap/>
1ec3d1a
#
1ec3d1a
interface(`postfix_read_config',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_etc_t;
1ec3d1a
	')
1ec3d1a
b43f464
	read_files_pattern($1, postfix_etc_t, postfix_etc_t)
b43f464
	read_lnk_files_pattern($1, postfix_etc_t, postfix_etc_t)
1ec3d1a
	files_search_etc($1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Create files with the specified type in
b43f464
##	the postfix configuration directories.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="private type">
1ec3d1a
##	<summary>
1ec3d1a
##	The type of the object to be created.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="object">
1ec3d1a
##	<summary>
1ec3d1a
##	The object class of the object being created.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
e96ffe5
## <param name="name" optional="true">
e96ffe5
##	<summary>
e96ffe5
##	The name of the object being created.
e96ffe5
##	</summary>
e96ffe5
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_config_filetrans',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_etc_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_etc($1)
1ec3d1a
	filetrans_pattern($1, postfix_etc_t, $2, $3, $4)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Do not audit attempts to read and
1ec3d1a
##	write postfix local delivery
1ec3d1a
##	TCP sockets.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain to not audit.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_dontaudit_rw_local_tcp_sockets',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_local_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	dontaudit $1 postfix_local_t:tcp_socket { read write };
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Allow read/write postfix local pipes
b43f464
##	TCP sockets.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_rw_local_pipes',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_local_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_local_t:fifo_file rw_fifo_file_perms;
1ec3d1a
')
1ec3d1a
48512f7
#######################################
48512f7
## <summary>
48512f7
##  Allow read/write postfix public pipes
48512f7
##  TCP sockets.
48512f7
## </summary>
48512f7
## <param name="domain">
48512f7
##  <summary>
48512f7
##  Domain allowed access.
48512f7
##  </summary>
48512f7
## </param>
48512f7
#
48512f7
interface(`postfix_rw_public_pipes',`
48512f7
    gen_require(`
48512f7
        type postfix_public_t;
48512f7
    ')
48512f7
270da9d
    allow $1 postfix_public_t:fifo_file rw_fifo_file_perms;
48512f7
')
48512f7
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Allow domain to read postfix local process state
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_read_local_state',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_local_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	kernel_search_proc($1)
1ec3d1a
	ps_process_pattern($1, postfix_local_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Allow domain to read postfix master process state
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_read_master_state',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	kernel_search_proc($1)
1ec3d1a
	ps_process_pattern($1, postfix_master_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Use postfix master process file
1ec3d1a
##	file descriptors.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_use_fds_master',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_master_t:fd use;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Do not audit attempts to use
1ec3d1a
##	postfix master process file
1ec3d1a
##	file descriptors.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain to not audit.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_dontaudit_use_fds',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	dontaudit $1 postfix_master_t:fd use;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute postfix_map in the postfix_map domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_domtrans_map',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_map_t, postfix_map_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, postfix_map_exec_t, postfix_map_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Execute postfix_map in the postfix_map domain, and
b43f464
##	allow the specified role the postfix_map domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="role">
1ec3d1a
##	<summary>
1ec3d1a
##	Role allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <rolecap/>
1ec3d1a
#
1ec3d1a
interface(`postfix_run_map',`
1ec3d1a
	gen_require(`
b43f464
		type postfix_map_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	postfix_domtrans_map($1)
b43f464
	role $2 types postfix_map_t;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Execute the master postfix program in the
b43f464
##	postfix_master domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_domtrans_master',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_t, postfix_master_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, postfix_master_exec_t, postfix_master_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute the master postfix in the postfix master domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_initrc_domtrans',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_initrc_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	init_labeled_script_domtrans($1, postfix_initrc_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Execute the master postfix program in the
b43f464
##	caller domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_exec_master',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	can_exec($1, postfix_master_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
#######################################
1ec3d1a
## <summary>
b43f464
##	Connect to postfix master process using a unix domain stream socket.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_stream_connect_master',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_t, postfix_public_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	stream_connect_pattern($1, postfix_public_t, postfix_public_t, postfix_master_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Allow read/write postfix master pipes
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1f86dac
interface(`postfix_rw_inherited_master_pipes',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_master_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_master_t:fifo_file rw_inherited_fifo_file_perms;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute the master postdrop in the
b43f464
##	postfix_postdrop domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_domtrans_postdrop',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_postdrop_t, postfix_postdrop_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, postfix_postdrop_exec_t, postfix_postdrop_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute the master postqueue in the
b43f464
##	postfix_postqueue domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_domtrans_postqueue',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_postqueue_t, postfix_postqueue_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, postfix_postqueue_exec_t, postfix_postqueue_t)
1ec3d1a
')
1ec3d1a
ea71a19
########################################
ea71a19
## <summary>
35c8f95
##	Execute the master postqueue in the
35c8f95
##	postfix_postdrop domain.
35c8f95
## </summary>
35c8f95
## <param name="domain">
35c8f95
##	<summary>
35c8f95
##	Domain allowed to transition.
35c8f95
##	</summary>
35c8f95
## </param>
35c8f95
## <param name="role">
35c8f95
##  <summary>
35c8f95
##  The role to be allowed the iptables domain.
35c8f95
##  </summary>
35c8f95
## </param>
35c8f95
## <rolecap/>
35c8f95
#
35c8f95
35c8f95
interface(`postfix_run_postqueue',`
35c8f95
	gen_require(`
35c8f95
		type postfix_postqueue_t;
35c8f95
	')
35c8f95
35c8f95
	postfix_domtrans_postqueue($1)
35c8f95
	role $2 types postfix_postqueue_t;
35c8f95
	allow postfix_postqueue_t $1:unix_stream_socket { read write getattr };
35c8f95
')
35c8f95
35c8f95
########################################
35c8f95
## <summary>
ea71a19
##	Execute postfix_postgqueue in the postfix_postgqueue domain, and
ea71a19
##	allow the specified role the postfix_postgqueue domain.
ea71a19
## </summary>
ea71a19
## <param name="domain">
ea71a19
##	<summary>
ea71a19
##	Domain allowed to transition.
ea71a19
##	</summary>
ea71a19
## </param>
ea71a19
## <param name="role">
ea71a19
##	<summary>
ea71a19
##	Role allowed access.
ea71a19
##	</summary>
ea71a19
## </param>
ea71a19
## <rolecap/>
ea71a19
#
ea71a19
interface(`postfix_run_postgqueue',`
ea71a19
	gen_require(`
ea71a19
		type postfix_postgqueue_t;
ea71a19
	')
ea71a19
ea71a19
	postfix_domtrans_postgqueue($1)
ea71a19
	role $2 types postfix_postgqueue_t;
ea71a19
')
ea71a19
ea71a19
1ec3d1a
#######################################
1ec3d1a
## <summary>
b43f464
##	Execute the master postqueue in the caller domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_exec_postqueue',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_postqueue_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	can_exec($1, postfix_postqueue_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Create a named socket in a postfix private directory.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_create_private_sockets',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_private_t;
1ec3d1a
	')
1ec3d1a
b43f464
	allow $1 postfix_private_t:dir list_dir_perms;
1ec3d1a
	create_sock_files_pattern($1, postfix_private_t, postfix_private_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	manage named socket in a postfix private directory.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_manage_private_sockets',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_private_t;
1ec3d1a
	')
1ec3d1a
b43f464
	allow $1 postfix_private_t:dir list_dir_perms;
1ec3d1a
	manage_sock_files_pattern($1, postfix_private_t, postfix_private_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Execute the master postfix program in the
b43f464
##	postfix_master domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_domtrans_smtp',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_smtp_t, postfix_smtp_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	domtrans_pattern($1, postfix_smtp_exec_t, postfix_smtp_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Getattr postfix mail spool files.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_getattr_spool_files',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_spool_type;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_spool($1)
1ec3d1a
	getattr_files_pattern($1, postfix_spool_type, postfix_spool_type)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Search postfix mail spool directories.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_search_spool',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_spool_type;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_spool_type:dir search_dir_perms;
1ec3d1a
	files_search_spool($1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	List postfix mail spool directories.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_list_spool',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_spool_type;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_spool_type:dir list_dir_perms;
1ec3d1a
	files_search_spool($1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Read postfix mail spool files.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_read_spool_files',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_spool_type;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_spool($1)
1ec3d1a
	read_files_pattern($1, postfix_spool_type, postfix_spool_type)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
b43f464
##	Create, read, write, and delete postfix mail spool files.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_manage_spool_files',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_spool_type;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_spool($1)
1ec3d1a
	manage_files_pattern($1, postfix_spool_type, postfix_spool_type)
1ec3d1a
')
1ec3d1a
81dae80
#######################################
81dae80
## <summary>
81dae80
##  Create, read, write, and delete postfix maildrop spool files.
81dae80
## </summary>
81dae80
## <param name="domain">
81dae80
##  <summary>
81dae80
##  Domain allowed access.
81dae80
##  </summary>
81dae80
## </param>
81dae80
#
81dae80
interface(`postfix_manage_spool_maildrop_files',`
81dae80
    gen_require(`
81dae80
        type postfix_spool_maildrop_t;
81dae80
    ')
81dae80
81dae80
    files_search_spool($1)
81dae80
    manage_dirs_pattern($1, postfix_spool_maildrop_t, postfix_spool_maildrop_t)
81dae80
    manage_files_pattern($1, postfix_spool_maildrop_t, postfix_spool_maildrop_t)
81dae80
')
81dae80
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute postfix user mail programs
1ec3d1a
##	in their respective domains.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_domtrans_user_mail_handler',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_user_domtrans;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	typeattribute $1 postfix_user_domtrans;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	All of the rules required to administrate
1ec3d1a
##	an postfix environment.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="role">
1ec3d1a
##	<summary>
1ec3d1a
##	Role allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <rolecap/>
1ec3d1a
#
1ec3d1a
interface(`postfix_admin',`
1ec3d1a
	gen_require(`
1ec3d1a
		attribute postfix_spool_type;
1ec3d1a
		type postfix_bounce_t, postfix_cleanup_t, postfix_local_t;
1ec3d1a
		type postfix_master_t, postfix_pickup_t, postfix_qmgr_t;
1ec3d1a
		type postfix_initrc_exec_t, postfix_data_t, postfix_etc_t;
1ec3d1a
		type postfix_map_tmp_t, postfix_prng_t, postfix_public_t;
1ec3d1a
		type postfix_smtpd_t, postfix_var_run_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_bounce_t:process signal_perms;
1ec3d1a
	ps_process_pattern($1, postfix_bounce_t)
1ec3d1a
	tunable_policy(`deny_ptrace',`',`
1ec3d1a
		allow $1 postfix_bounce_t:process ptrace;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_cleanup_t:process signal_perms;
1ec3d1a
	ps_process_pattern($1, postfix_cleanup_t)
1ec3d1a
	tunable_policy(`deny_ptrace',`',`
1ec3d1a
		allow $1 postfix_cleanup_t:process ptrace;
1ec3d1a
		allow $1 postfix_local_t:process ptrace;
1ec3d1a
		allow $1 postfix_master_t:process ptrace;
1ec3d1a
		allow $1 postfix_pickup_t:process ptrace;
1ec3d1a
		allow $1 postfix_qmgr_t:process ptrace;
1ec3d1a
		allow $1 postfix_smtpd_t:process ptrace;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 postfix_local_t:process signal_perms;
1ec3d1a
	ps_process_pattern($1, postfix_local_t)
1ec3d1a
1ec3d1a
	allow $1 postfix_master_t:process signal_perms;
1ec3d1a
	ps_process_pattern($1, postfix_master_t)
1ec3d1a
1ec3d1a
	allow $1 postfix_pickup_t:process signal_perms;
1ec3d1a
	ps_process_pattern($1, postfix_pickup_t)
1ec3d1a
1ec3d1a
	allow $1 postfix_qmgr_t:process signal_perms;
1ec3d1a
	ps_process_pattern($1, postfix_qmgr_t)
1ec3d1a
1ec3d1a
	allow $1 postfix_smtpd_t:process signal_perms;
1ec3d1a
	ps_process_pattern($1, postfix_smtpd_t)
1ec3d1a
1ec3d1a
	postfix_run_map($1, $2)
1ec3d1a
	postfix_run_postdrop($1, $2)
ea71a19
	postfix_run_postqueue($1, $2)
1ec3d1a
1ec3d1a
	postfix_initrc_domtrans($1)
1ec3d1a
	domain_system_change_exemption($1)
1ec3d1a
	role_transition $2 postfix_initrc_exec_t system_r;
1ec3d1a
	allow $2 system_r;
1ec3d1a
1ec3d1a
	admin_pattern($1, postfix_data_t) 
1ec3d1a
1ec3d1a
	files_list_etc($1)
1ec3d1a
	admin_pattern($1, postfix_etc_t)
1ec3d1a
1ec3d1a
	files_list_spool($1)
1ec3d1a
	admin_pattern($1, postfix_spool_type)
1ec3d1a
1ec3d1a
	admin_pattern($1, postfix_var_run_t)
1ec3d1a
1ec3d1a
	files_list_tmp($1)
1ec3d1a
	admin_pattern($1, postfix_map_tmp_t)
1ec3d1a
	
1ec3d1a
	admin_pattern($1, postfix_prng_t)
1ec3d1a
1ec3d1a
	admin_pattern($1, postfix_public_t)
1ec3d1a
1ec3d1a
	postfix_filetrans_named_content($1)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute the master postdrop in the
1ec3d1a
##	postfix_postdrop domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
## <param name="role">
1ec3d1a
##  <summary>
1ec3d1a
##  The role to be allowed the iptables domain.
1ec3d1a
##  </summary>
1ec3d1a
## </param>
1ec3d1a
## <rolecap/>
1ec3d1a
#
1ec3d1a
interface(`postfix_run_postdrop',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_postdrop_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	postfix_domtrans_postdrop($1)
1ec3d1a
	role $2 types postfix_postdrop_t;
c33293b
	allow postfix_postdrop_t $1:unix_stream_socket { read write getattr };
1ec3d1a
')
1ec3d1a
35c8f95
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute postfix exec in the users domain
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##      Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_exec',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	can_exec($1, postfix_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Transition to postfix named content
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##      Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`postfix_filetrans_named_content',`
1ec3d1a
	gen_require(`
1ec3d1a
		type postfix_exec_t;
1ec3d1a
		type postfix_prng_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	postfix_config_filetrans($1, postfix_exec_t, file, "postfix-script")
1ec3d1a
	postfix_config_filetrans($1, postfix_prng_t, file, "prng_exch")
1ec3d1a
')