1ec3d1a
## <summary>Rotate and archive system logs</summary>
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute logrotate in the logrotate domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed to transition.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`logrotate_domtrans',`
1ec3d1a
	gen_require(`
1ec3d1a
		type logrotate_t, logrotate_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	corecmd_search_bin($1)
1ec3d1a
	domtrans_pattern($1, logrotate_exec_t, logrotate_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute logrotate in the logrotate domain, and
1ec3d1a
##	allow the specified role the logrotate 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(`logrotate_run',`
1ec3d1a
	gen_require(`
1ec3d1a
		type logrotate_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	logrotate_domtrans($1)
1ec3d1a
	role $2 types logrotate_t;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Execute logrotate in the caller domain.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`logrotate_exec',`
1ec3d1a
	gen_require(`
1ec3d1a
		type logrotate_exec_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	corecmd_search_bin($1)
1ec3d1a
	can_exec($1, logrotate_exec_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Inherit and use logrotate file descriptors.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`logrotate_use_fds',`
1ec3d1a
	gen_require(`
1ec3d1a
		type logrotate_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	allow $1 logrotate_t:fd use;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Do not audit attempts to inherit logrotate file descriptors.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain to not audit.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`logrotate_dontaudit_use_fds',`
1ec3d1a
	gen_require(`
1ec3d1a
		type logrotate_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	dontaudit $1 logrotate_t:fd use;
1ec3d1a
')
1ec3d1a
1ec3d1a
########################################
1ec3d1a
## <summary>
1ec3d1a
##	Read a logrotate temporary files.
1ec3d1a
## </summary>
1ec3d1a
## <param name="domain">
1ec3d1a
##	<summary>
1ec3d1a
##	Domain allowed access.
1ec3d1a
##	</summary>
1ec3d1a
## </param>
1ec3d1a
#
1ec3d1a
interface(`logrotate_read_tmp_files',`
1ec3d1a
	gen_require(`
1ec3d1a
		type logrotate_tmp_t;
1ec3d1a
	')
1ec3d1a
1ec3d1a
	files_search_tmp($1)
1ec3d1a
	allow $1 logrotate_tmp_t:file read_file_perms;
1ec3d1a
')