Chris PeBenito 0f707d5
## <summary>Squid caching http proxy server</summary>
Chris PeBenito 0f707d5
Chris PeBenito 0f707d5
########################################
Chris PeBenito 0f707d5
## <summary>
Chris PeBenito 0f707d5
##	Execute squid in the squid domain.
Chris PeBenito 0f707d5
## </summary>
Chris PeBenito 0f707d5
## <param name="domain">
Chris PeBenito 0f707d5
##	The type of the process performing this action.
Chris PeBenito 0f707d5
## </param>
Chris PeBenito 0f707d5
#
Chris PeBenito 0f707d5
interface(`squid_domtrans',`
Chris PeBenito 0f707d5
	gen_require(`
Chris PeBenito 0f707d5
		type squid_t, squid_exec_t;
Chris PeBenito 0f707d5
	')
Chris PeBenito 0f707d5
Chris PeBenito 0f707d5
	corecmd_search_sbin($1)
Chris PeBenito 0f707d5
	domain_auto_trans($1,squid_exec_t,squid_t)
Chris PeBenito 0f707d5
Chris PeBenito 0f707d5
	allow $1 squid_t:fd use;
Chris PeBenito 0f707d5
	allow squid_t $1:fd use;
Chris PeBenito 0f707d5
	allow squid_t $1:fifo_file rw_file_perms;
Chris PeBenito 0f707d5
	allow squid_t $1:process sigchld;
Chris PeBenito 0f707d5
')
Chris PeBenito 0f707d5
Chris PeBenito 0f707d5
########################################
Chris PeBenito 0f707d5
## <summary>
Chris PeBenito 0f707d5
##	Read squid configuration file.
Chris PeBenito 0f707d5
## </summary>
Chris PeBenito 0f707d5
## <param name="domain">
Chris PeBenito 0f707d5
##	Domain allowed access.
Chris PeBenito 0f707d5
## </param>
Chris PeBenito 0f707d5
#
Chris PeBenito 0f707d5
interface(`squid_read_config',`
Chris PeBenito 0f707d5
	gen_require(`
Chris PeBenito 0f707d5
		type squid_conf_t;
Chris PeBenito 0f707d5
	')
Chris PeBenito 0f707d5
Chris PeBenito 0f707d5
	files_search_etc($1)
Chris PeBenito 0f707d5
	allow $1 squid_conf_t:file r_file_perms;
Chris PeBenito 0f707d5
')
Chris PeBenito 0f707d5
Chris PeBenito 0f707d5
########################################
Chris PeBenito 0f707d5
## <summary>
Chris PeBenito 6716737
##	Append squid logs.
Chris PeBenito 6716737
## </summary>
Chris PeBenito 6716737
## <param name="domain">
Chris PeBenito 6716737
##	Domain allowed access.
Chris PeBenito 6716737
## </param>
Chris PeBenito 6716737
#
Chris PeBenito 6716737
interface(`squid_read_log',`
Chris PeBenito 6716737
	gen_require(`
Chris PeBenito 6716737
		type squid_log_t;
Chris PeBenito 6716737
	')
Chris PeBenito 6716737
Chris PeBenito 6716737
	logging_search_logs($1)
Chris PeBenito 6716737
	allow $1 squid_log_t:dir search_dir_perms;
Chris PeBenito 6716737
	allow $1 squid_log_t:file r_file_perms;
Chris PeBenito 6716737
')
Chris PeBenito 6716737
Chris PeBenito 6716737
########################################
Chris PeBenito 6716737
## <summary>
Chris PeBenito 6716737
##	Append squid logs.
Chris PeBenito 6716737
## </summary>
Chris PeBenito 6716737
## <param name="domain">
Chris PeBenito 6716737
##	Domain allowed access.
Chris PeBenito 6716737
## </param>
Chris PeBenito 6716737
#
Chris PeBenito 6716737
interface(`squid_append_log',`
Chris PeBenito 6716737
	gen_require(`
Chris PeBenito 6716737
		type squid_log_t;
Chris PeBenito 6716737
	')
Chris PeBenito 6716737
Chris PeBenito 6716737
	logging_search_logs($1)
Chris PeBenito 6716737
	allow $1 squid_log_t:dir search_dir_perms;
Chris PeBenito 6716737
	allow $1 squid_log_t:file { getattr append };
Chris PeBenito 6716737
')
Chris PeBenito 6716737
Chris PeBenito 6716737
########################################
Chris PeBenito 6716737
## <summary>
Chris PeBenito 6716737
##	Create, read, write, and delete
Chris PeBenito 6716737
##	squid logs.
Chris PeBenito 6716737
## </summary>
Chris PeBenito 6716737
## <param name="domain">
Chris PeBenito 6716737
##	Domain allowed access.
Chris PeBenito 6716737
## </param>
Chris PeBenito 6716737
#
Chris PeBenito 6716737
interface(`squid_manage_logs',`
Chris PeBenito 6716737
	gen_require(`
Chris PeBenito 6716737
		type squid_log_t;
Chris PeBenito 6716737
	')
Chris PeBenito 6716737
Chris PeBenito 6716737
	logging_search_logs($1)
Chris PeBenito 6716737
	allow $1 squid_log_t:dir rw_dir_perms;
Chris PeBenito 6716737
	allow $1 squid_log_t:file create_file_perms;
Chris PeBenito 6716737
')
Chris PeBenito 6716737
Chris PeBenito 6716737
########################################
Chris PeBenito 6716737
## <summary>
Chris PeBenito 0f707d5
##	Use squid services by connecting over TCP.
Chris PeBenito 0f707d5
## </summary>
Chris PeBenito 0f707d5
## <param name="domain">
Chris PeBenito 0f707d5
##	Domain allowed access.
Chris PeBenito 0f707d5
## </param>
Chris PeBenito 0f707d5
#
Chris PeBenito 0f707d5
interface(`squid_use',`
Chris PeBenito 0f707d5
	gen_require(`
Chris PeBenito 0f707d5
		type squid_t;
Chris PeBenito 0f707d5
	')
Chris PeBenito 0f707d5
Chris PeBenito 0f707d5
	allow $1 squid_t:tcp_socket { connectto recvfrom };
Chris PeBenito 0f707d5
	allow squid_t $1:tcp_socket { acceptfrom recvfrom };
Chris PeBenito 0f707d5
	kernel_tcp_recvfrom($1)
Chris PeBenito 0f707d5
')