|
Chris PeBenito |
17de1b |
## <summary>Policy for the kernel message logger and system logging daemon.</summary>
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
45185c |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
45185c |
## Make the specified type usable for log files
|
|
Chris PeBenito |
45185c |
## in a filesystem.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
45185c |
## <desc>
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
## Make the specified type usable for log files in a filesystem.
|
|
Chris PeBenito |
45185c |
## This will also make the type usable for files, making
|
|
Chris PeBenito |
45185c |
## calls to files_type() redundant. Failure to use this interface
|
|
Chris PeBenito |
45185c |
## for a log file type may result in problems with log
|
|
Chris PeBenito |
45185c |
## rotation, log analysis, and log monitoring programs.
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
## Related interfaces:
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
## logging_log_filetrans()
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
## Example usage with a domain that can create
|
|
Chris PeBenito |
45185c |
## and append to a private log file stored in the
|
|
Chris PeBenito |
45185c |
## general directories (e.g., /var/log):
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
## type mylogfile_t;
|
|
Chris PeBenito |
45185c |
## logging_log_file(mylogfile_t)
|
|
Chris PeBenito |
45185c |
## allow mydomain_t mylogfile_t:file { create_file_perms append_file_perms };
|
|
Chris PeBenito |
45185c |
## logging_log_filetrans(mydomain_t, mylogfile_t, file)
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
## </desc>
|
|
Chris PeBenito |
45185c |
## <param name="type">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
45185c |
## Type to be used for files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
45185c |
## <infoflow type="none"/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_log_file',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
attribute logfile;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_type($1)
|
|
Chris PeBenito |
17de1b |
files_associate_tmp($1)
|
|
Chris PeBenito |
17de1b |
fs_associate_tmpfs($1)
|
|
Chris PeBenito |
17de1b |
typeattribute $1 logfile;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
d5b81a |
#######################################
|
|
Chris PeBenito |
d5b81a |
## <summary>
|
|
Chris PeBenito |
d5b81a |
## Send audit messages.
|
|
Chris PeBenito |
d5b81a |
## </summary>
|
|
Chris PeBenito |
d5b81a |
## <param name="domain">
|
|
Chris PeBenito |
d5b81a |
## <summary>
|
|
Chris PeBenito |
d5b81a |
## Domain allowed access.
|
|
Chris PeBenito |
d5b81a |
## </summary>
|
|
Chris PeBenito |
d5b81a |
## </param>
|
|
Chris PeBenito |
d5b81a |
#
|
|
Chris PeBenito |
d5b81a |
interface(`logging_send_audit_msgs',`
|
|
Chris PeBenito |
d5b81a |
allow $1 self:capability audit_write;
|
|
Chris PeBenito |
eaed90 |
allow $1 self:netlink_audit_socket { r_netlink_socket_perms nlmsg_relay };
|
|
Chris PeBenito |
eaed90 |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
#######################################
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## dontaudit attempts to send audit messages.
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## <param name="domain">
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain to not audit.
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## </param>
|
|
Chris PeBenito |
eaed90 |
#
|
|
Chris PeBenito |
eaed90 |
interface(`logging_dontaudit_send_audit_msgs',`
|
|
Chris PeBenito |
eaed90 |
dontaudit $1 self:capability audit_write;
|
|
Chris PeBenito |
eaed90 |
dontaudit $1 self:netlink_audit_socket { r_netlink_socket_perms nlmsg_relay };
|
|
Chris PeBenito |
eaed90 |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
########################################
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## Set login uid
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## <param name="domain">
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## Domain allowed access.
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## </param>
|
|
Chris PeBenito |
eaed90 |
#
|
|
Chris PeBenito |
eaed90 |
interface(`logging_set_loginuid',`
|
|
Chris PeBenito |
eaed90 |
allow $1 self:capability audit_control;
|
|
Chris PeBenito |
eaed90 |
allow $1 self:netlink_audit_socket { r_netlink_socket_perms nlmsg_relay };
|
|
Chris PeBenito |
eaed90 |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
########################################
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
7a8807 |
## Set tty auditing
|
|
Chris PeBenito |
7a8807 |
## </summary>
|
|
Chris PeBenito |
7a8807 |
## <param name="domain">
|
|
Chris PeBenito |
7a8807 |
## <summary>
|
|
Chris PeBenito |
7a8807 |
## Domain allowed access.
|
|
Chris PeBenito |
7a8807 |
## </summary>
|
|
Chris PeBenito |
7a8807 |
## </param>
|
|
Chris PeBenito |
7a8807 |
#
|
|
Chris PeBenito |
7a8807 |
interface(`logging_set_tty_audit',`
|
|
Chris PeBenito |
7a8807 |
allow $1 self:netlink_audit_socket { r_netlink_socket_perms nlmsg_tty_audit };
|
|
Chris PeBenito |
7a8807 |
')
|
|
Chris PeBenito |
7a8807 |
|
|
Chris PeBenito |
7a8807 |
########################################
|
|
Chris PeBenito |
7a8807 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## Set up audit
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## <param name="domain">
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## Domain allowed access.
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## </param>
|
|
Chris PeBenito |
eaed90 |
#
|
|
Chris PeBenito |
eaed90 |
interface(`logging_set_audit_parameters',`
|
|
Chris PeBenito |
eaed90 |
allow $1 self:capability { audit_write audit_control };
|
|
Chris PeBenito |
d5b81a |
allow $1 self:netlink_audit_socket { create_netlink_socket_perms nlmsg_relay };
|
|
Chris PeBenito |
d5b81a |
')
|
|
Chris PeBenito |
d5b81a |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Read the audit log.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_read_audit_log',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditd_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
3f67f7 |
read_files_pattern($1, auditd_log_t, auditd_log_t)
|
|
Chris PeBenito |
c0868a |
allow $1 auditd_log_t:dir list_dir_perms;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Execute auditctl in the auditctl domain.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain allowed to transition.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_domtrans_auditctl',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditctl_t, auditctl_exec_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
3f67f7 |
domtrans_pattern($1, auditctl_exec_t, auditctl_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Execute auditctl in the auditctl domain, and
|
|
Chris PeBenito |
17de1b |
## allow the specified role the auditctl domain.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain allowed to transition.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
## <param name="role">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
a7ee7f |
## Role allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_run_auditctl',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditctl_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
logging_domtrans_auditctl($1)
|
|
Chris PeBenito |
17de1b |
role $2 types auditctl_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Execute auditd in the auditd domain.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain allowed to transition.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_domtrans_auditd',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditd_t, auditd_exec_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
3f67f7 |
domtrans_pattern($1, auditd_exec_t, auditd_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Execute auditd in the auditd domain, and
|
|
Chris PeBenito |
17de1b |
## allow the specified role the auditd domain.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain allowed to transition.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
## <param name="role">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
a7ee7f |
## Role allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_run_auditd',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditd_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
logging_domtrans_auditd($1)
|
|
Chris PeBenito |
17de1b |
role $2 types auditd_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
a5e213 |
## Connect to auditdstored over an unix stream socket.
|
|
Chris PeBenito |
a5e213 |
## </summary>
|
|
Chris PeBenito |
a5e213 |
## <param name="domain">
|
|
Chris PeBenito |
a5e213 |
## <summary>
|
|
Chris PeBenito |
a5e213 |
## Domain allowed access.
|
|
Chris PeBenito |
a5e213 |
## </summary>
|
|
Chris PeBenito |
a5e213 |
## </param>
|
|
Chris PeBenito |
a5e213 |
#
|
|
Chris PeBenito |
a5e213 |
interface(`logging_stream_connect_auditd',`
|
|
Chris PeBenito |
c11057 |
refpolicywarn(`$0($*) has been deprecated, logging_stream_connect_dispatcher() should be used instead.')
|
|
Chris PeBenito |
c11057 |
logging_stream_connect_dispatcher($1)
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
########################################
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Execute a domain transition to run the audit dispatcher.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## <param name="domain">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Domain allowed to transition.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
c11057 |
#
|
|
Chris PeBenito |
c11057 |
interface(`logging_domtrans_dispatcher',`
|
|
Chris PeBenito |
a5e213 |
gen_require(`
|
|
Chris PeBenito |
c11057 |
type audisp_t, audisp_exec_t;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
domtrans_pattern($1, audisp_exec_t, audisp_t)
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
########################################
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Signal the audit dispatcher.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## <param name="domain">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain allowed access.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
c11057 |
#
|
|
Chris PeBenito |
c11057 |
interface(`logging_signal_dispatcher',`
|
|
Chris PeBenito |
c11057 |
gen_require(`
|
|
Chris PeBenito |
c11057 |
type audisp_t;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
allow $1 audisp_t:process signal;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
########################################
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Create a domain for processes
|
|
Chris PeBenito |
c11057 |
## which can be started by the system audit dispatcher
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## <param name="domain">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Type to be used as a domain.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
c11057 |
## <param name="entry_point">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Type of the program to be used as an entry point to this domain.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
c11057 |
#
|
|
Chris PeBenito |
c11057 |
interface(`logging_dispatcher_domain',`
|
|
Chris PeBenito |
c11057 |
gen_require(`
|
|
Chris PeBenito |
c11057 |
type audisp_t;
|
|
Chris PeBenito |
c11057 |
role system_r;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
domain_type($1)
|
|
Chris PeBenito |
c11057 |
domain_entry_file($1, $2)
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
role system_r types $1;
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
domtrans_pattern(audisp_t, $2, $1)
|
|
Chris PeBenito |
cfafe4 |
allow audisp_t $1:process { sigkill sigstop signull signal };
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
allow audisp_t $2:file getattr;
|
|
Chris PeBenito |
c11057 |
allow $1 audisp_t:unix_stream_socket rw_socket_perms;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
########################################
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Connect to the audit dispatcher over an unix stream socket.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## <param name="domain">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Domain allowed access.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
c11057 |
#
|
|
Chris PeBenito |
c11057 |
interface(`logging_stream_connect_dispatcher',`
|
|
Chris PeBenito |
c11057 |
gen_require(`
|
|
Chris PeBenito |
c11057 |
type audisp_t, audisp_var_run_t;
|
|
Chris PeBenito |
a5e213 |
')
|
|
Chris PeBenito |
a5e213 |
|
|
Chris PeBenito |
a5e213 |
files_search_pids($1)
|
|
Chris PeBenito |
c11057 |
stream_connect_pattern($1, audisp_var_run_t, audisp_var_run_t, audisp_t)
|
|
Chris PeBenito |
a5e213 |
')
|
|
Chris PeBenito |
a5e213 |
|
|
Chris PeBenito |
a5e213 |
########################################
|
|
Chris PeBenito |
a5e213 |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Manage the auditd configuration files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_manage_audit_config',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditd_etc_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_etc($1)
|
|
Chris PeBenito |
3f67f7 |
manage_files_pattern($1, auditd_etc_t, auditd_etc_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Manage the audit log.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_manage_audit_log',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditd_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
3f67f7 |
manage_dirs_pattern($1, auditd_log_t, auditd_log_t)
|
|
Chris PeBenito |
3f67f7 |
manage_files_pattern($1, auditd_log_t, auditd_log_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
14add3 |
## Execute klogd in the klog domain.
|
|
Chris PeBenito |
14add3 |
## </summary>
|
|
Chris PeBenito |
14add3 |
## <param name="domain">
|
|
Chris PeBenito |
14add3 |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain allowed to transition.
|
|
Chris PeBenito |
14add3 |
## </summary>
|
|
Chris PeBenito |
14add3 |
## </param>
|
|
Chris PeBenito |
14add3 |
#
|
|
Chris PeBenito |
14add3 |
interface(`logging_domtrans_klog',`
|
|
Chris PeBenito |
14add3 |
gen_require(`
|
|
Chris PeBenito |
14add3 |
type klogd_t, klogd_exec_t;
|
|
Chris PeBenito |
14add3 |
')
|
|
Chris PeBenito |
14add3 |
|
|
Chris PeBenito |
14add3 |
corecmd_search_bin($1)
|
|
Chris PeBenito |
3f67f7 |
domtrans_pattern($1, klogd_exec_t, klogd_t)
|
|
Chris PeBenito |
14add3 |
')
|
|
Chris PeBenito |
14add3 |
|
|
Chris PeBenito |
14add3 |
########################################
|
|
Chris PeBenito |
14add3 |
## <summary>
|
|
Chris PeBenito |
e40fa6 |
## Check if syslogd is executable.
|
|
Chris PeBenito |
e40fa6 |
## </summary>
|
|
Chris PeBenito |
e40fa6 |
## <param name="domain">
|
|
Chris PeBenito |
e40fa6 |
## <summary>
|
|
Chris PeBenito |
e40fa6 |
## Domain allowed access.
|
|
Chris PeBenito |
e40fa6 |
## </summary>
|
|
Chris PeBenito |
e40fa6 |
## </param>
|
|
Chris PeBenito |
e40fa6 |
#
|
|
Chris PeBenito |
e40fa6 |
interface(`logging_check_exec_syslog',`
|
|
Chris PeBenito |
e40fa6 |
gen_require(`
|
|
Chris PeBenito |
96851b |
type syslogd_exec_t;
|
|
Chris PeBenito |
e40fa6 |
')
|
|
Chris PeBenito |
e40fa6 |
|
|
Chris PeBenito |
e40fa6 |
corecmd_list_bin($1)
|
|
Chris PeBenito |
e40fa6 |
corecmd_read_bin_symlinks($1)
|
|
Chris PeBenito |
e40fa6 |
allow $1 syslogd_exec_t:file execute;
|
|
Chris PeBenito |
e40fa6 |
')
|
|
Chris PeBenito |
e40fa6 |
|
|
Chris PeBenito |
e40fa6 |
########################################
|
|
Chris PeBenito |
e40fa6 |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Execute syslogd in the syslog domain.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain allowed to transition.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_domtrans_syslog',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type syslogd_t, syslogd_exec_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
8021cb |
corecmd_search_bin($1)
|
|
Chris PeBenito |
3f67f7 |
domtrans_pattern($1, syslogd_exec_t, syslogd_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
45185c |
## Create an object in the log directory, with a private type.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
45185c |
## <desc>
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
45185c |
## Allow the specified domain to create an object
|
|
Chris PeBenito |
45185c |
## in the general system log directories (e.g., /var/log)
|
|
Chris PeBenito |
45185c |
## with a private type. Typically this is used for creating
|
|
Chris PeBenito |
45185c |
## private log files in /var/log with the private type instead
|
|
Chris PeBenito |
45185c |
## of the general system log type. To accomplish this goal,
|
|
Chris PeBenito |
45185c |
## either the program must be SELinux-aware, or use this interface.
|
|
Chris PeBenito |
45185c |
##
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
5fb5bf |
## Related interfaces:
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
5fb5bf |
## logging_log_file()
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
5fb5bf |
## Example usage with a domain that can create
|
|
Chris PeBenito |
5fb5bf |
## and append to a private log file stored in the
|
|
Chris PeBenito |
5fb5bf |
## general directories (e.g., /var/log):
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
5fb5bf |
## type mylogfile_t;
|
|
Chris PeBenito |
5fb5bf |
## logging_log_file(mylogfile_t)
|
|
Chris PeBenito |
5fb5bf |
## allow mydomain_t mylogfile_t:file { create_file_perms append_file_perms };
|
|
Chris PeBenito |
5fb5bf |
## logging_log_filetrans(mydomain_t, mylogfile_t, file)
|
|
Chris PeBenito |
5fb5bf |
##
|
|
Chris PeBenito |
45185c |
## </desc>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
## <param name="private type">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## The type of the object to be created.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
## <param name="object">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## The object class of the object being created.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
45185c |
## <infoflow type="write" weight="10"/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_log_filetrans',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
3f67f7 |
filetrans_pattern($1, var_log_t, $2, $3)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Send system log messages.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
6e4877 |
## <desc>
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
## Allow the specified domain to connect to the
|
|
Chris PeBenito |
6e4877 |
## system log service (syslog), to send messages be added to
|
|
Chris PeBenito |
6e4877 |
## the system logs. Typically this is used by services
|
|
Chris PeBenito |
6e4877 |
## that do not have their own log file in /var/log.
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
## This does not allow messages to be sent to
|
|
Chris PeBenito |
6e4877 |
## the auditing system.
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
## Programs which use the libc function syslog() will
|
|
Chris PeBenito |
6e4877 |
## require this access.
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
## Related interfaces:
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
## logging_send_audit_msgs()
|
|
Chris PeBenito |
6e4877 |
##
|
|
Chris PeBenito |
6e4877 |
## </desc>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_send_syslog_msg',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type syslogd_t, devlog_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
fef5dc |
allow $1 devlog_t:lnk_file read_lnk_file_perms;
|
|
Chris PeBenito |
fef5dc |
allow $1 devlog_t:sock_file write_sock_file_perms;
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
# the type of socket depends on the syslog daemon
|
|
Chris PeBenito |
17de1b |
allow $1 syslogd_t:unix_dgram_socket sendto;
|
|
Chris PeBenito |
17de1b |
allow $1 syslogd_t:unix_stream_socket connectto;
|
|
Chris PeBenito |
17de1b |
allow $1 self:unix_dgram_socket create_socket_perms;
|
|
Chris PeBenito |
17de1b |
allow $1 self:unix_stream_socket create_socket_perms;
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
fef5dc |
# If syslog is down, the glibc syslog() function
|
|
Chris PeBenito |
fef5dc |
# will write to the console.
|
|
Chris PeBenito |
fef5dc |
term_write_console($1)
|
|
Chris PeBenito |
2f84a7 |
term_dontaudit_read_console($1)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Read the auditd configuration files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_read_audit_config',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type auditd_etc_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_etc($1)
|
|
Chris PeBenito |
3f67f7 |
read_files_pattern($1, auditd_etc_t, auditd_etc_t)
|
|
Chris PeBenito |
c0868a |
allow $1 auditd_etc_t:dir list_dir_perms;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
0a0b80 |
## dontaudit search of auditd configuration files.
|
|
Chris PeBenito |
0a0b80 |
## </summary>
|
|
Chris PeBenito |
0a0b80 |
## <param name="domain">
|
|
Chris PeBenito |
0a0b80 |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain to not audit.
|
|
Chris PeBenito |
0a0b80 |
## </summary>
|
|
Chris PeBenito |
0a0b80 |
## </param>
|
|
Chris PeBenito |
0a0b80 |
## <rolecap/>
|
|
Chris PeBenito |
0a0b80 |
#
|
|
Chris PeBenito |
0a0b80 |
interface(`logging_dontaudit_search_audit_config',`
|
|
Chris PeBenito |
0a0b80 |
gen_require(`
|
|
Chris PeBenito |
0a0b80 |
type auditd_etc_t;
|
|
Chris PeBenito |
0a0b80 |
')
|
|
Chris PeBenito |
0a0b80 |
|
|
Chris PeBenito |
0a0b80 |
dontaudit $1 auditd_etc_t:dir search_dir_perms;
|
|
Chris PeBenito |
0a0b80 |
')
|
|
Chris PeBenito |
0a0b80 |
|
|
Chris PeBenito |
0a0b80 |
########################################
|
|
Chris PeBenito |
0a0b80 |
## <summary>
|
|
Chris PeBenito |
1abafe |
## Read syslog configuration files.
|
|
Chris PeBenito |
1abafe |
## </summary>
|
|
Chris PeBenito |
1abafe |
## <param name="domain">
|
|
Chris PeBenito |
1abafe |
## <summary>
|
|
Chris PeBenito |
1abafe |
## Domain allowed access.
|
|
Chris PeBenito |
1abafe |
## </summary>
|
|
Chris PeBenito |
1abafe |
## </param>
|
|
Chris PeBenito |
1abafe |
## <rolecap/>
|
|
Chris PeBenito |
1abafe |
#
|
|
Chris PeBenito |
1abafe |
interface(`logging_read_syslog_config',`
|
|
Chris PeBenito |
1abafe |
gen_require(`
|
|
Chris PeBenito |
1abafe |
type syslog_conf_t;
|
|
Chris PeBenito |
1abafe |
')
|
|
Chris PeBenito |
1abafe |
|
|
Chris PeBenito |
1abafe |
allow $1 syslog_conf_t:file read_file_perms;
|
|
Chris PeBenito |
1abafe |
')
|
|
Chris PeBenito |
1abafe |
|
|
Chris PeBenito |
1abafe |
########################################
|
|
Chris PeBenito |
1abafe |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Allows the domain to open a file in the
|
|
Chris PeBenito |
17de1b |
## log directory, but does not allow the listing
|
|
Chris PeBenito |
17de1b |
## of the contents of the log directory.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_search_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
465510 |
allow $1 var_log_t:dir search_dir_perms;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
#######################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
ff8f0a |
## Do not audit attempts to search the var log directory.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
ff8f0a |
## <summary>
|
|
Chris PeBenito |
ff8f0a |
## Domain not to audit.
|
|
Chris PeBenito |
ff8f0a |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_dontaudit_search_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
465510 |
dontaudit $1 var_log_t:dir search_dir_perms;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
#######################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## List the contents of the generic log directory (/var/log).
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_list_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
c0868a |
allow $1 var_log_t:dir list_dir_perms;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
#######################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Read and write the generic log directory (/var/log).
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_rw_generic_log_dirs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
17de1b |
allow $1 var_log_t:dir rw_dir_perms;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Do not audit attempts to get the atttributes
|
|
Chris PeBenito |
17de1b |
## of any log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain to not audit.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_dontaudit_getattr_all_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
attribute logfile;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
dontaudit $1 logfile:file getattr;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Append to all log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_append_all_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
attribute logfile;
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
c11057 |
append_files_pattern($1, var_log_t, logfile)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Read all log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_read_all_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
attribute logfile;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
eaed90 |
allow $1 logfile:dir list_dir_perms;
|
|
Chris PeBenito |
eaed90 |
read_files_pattern($1, logfile, logfile)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Execute all log files in the caller domain.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
# cjp: not sure why this is needed. This was added
|
|
Chris PeBenito |
17de1b |
# because of logrotate.
|
|
Chris PeBenito |
17de1b |
interface(`logging_exec_all_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
attribute logfile;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
c0868a |
allow $1 logfile:dir list_dir_perms;
|
|
Chris PeBenito |
3f67f7 |
can_exec($1, logfile)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
c11057 |
## read/write to all log files.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## <param name="domain">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Domain allowed access.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
c11057 |
#
|
|
Chris PeBenito |
c11057 |
interface(`logging_rw_all_logs',`
|
|
Chris PeBenito |
c11057 |
gen_require(`
|
|
Chris PeBenito |
c11057 |
attribute logfile;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
files_search_var($1)
|
|
Chris PeBenito |
c11057 |
rw_files_pattern($1, logfile, logfile)
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
########################################
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Create, read, write, and delete all log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_manage_all_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
attribute logfile;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
3f67f7 |
manage_files_pattern($1, logfile, logfile)
|
|
Chris PeBenito |
3f67f7 |
read_lnk_files_pattern($1, logfile, logfile)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Read generic log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_read_generic_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
c0868a |
allow $1 var_log_t:dir list_dir_perms;
|
|
Chris PeBenito |
3f67f7 |
read_files_pattern($1, var_log_t, var_log_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Write generic log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_write_generic_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
c0868a |
allow $1 var_log_t:dir list_dir_perms;
|
|
Chris PeBenito |
3f67f7 |
write_files_pattern($1, var_log_t, var_log_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
c11057 |
## Dontaudit Write generic log files.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## <param name="domain">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Dominick Grift |
a0546c |
## Domain to not audit.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
c11057 |
#
|
|
Chris PeBenito |
c11057 |
interface(`logging_dontaudit_write_generic_logs',`
|
|
Chris PeBenito |
c11057 |
gen_require(`
|
|
Chris PeBenito |
c11057 |
type var_log_t;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
dontaudit $1 var_log_t:file write;
|
|
Chris PeBenito |
c11057 |
')
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
c11057 |
########################################
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Read and write generic log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_rw_generic_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
c0868a |
allow $1 var_log_t:dir list_dir_perms;
|
|
Chris PeBenito |
3f67f7 |
rw_files_pattern($1, var_log_t, var_log_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
########################################
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Create, read, write, and delete
|
|
Chris PeBenito |
17de1b |
## generic log files.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## <param name="domain">
|
|
Chris PeBenito |
17de1b |
## <summary>
|
|
Chris PeBenito |
17de1b |
## Domain allowed access.
|
|
Chris PeBenito |
17de1b |
## </summary>
|
|
Chris PeBenito |
17de1b |
## </param>
|
|
Chris PeBenito |
bbcd3c |
## <rolecap/>
|
|
Chris PeBenito |
17de1b |
#
|
|
Chris PeBenito |
17de1b |
interface(`logging_manage_generic_logs',`
|
|
Chris PeBenito |
17de1b |
gen_require(`
|
|
Chris PeBenito |
17de1b |
type var_log_t;
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
17de1b |
|
|
Chris PeBenito |
17de1b |
files_search_var($1)
|
|
Chris PeBenito |
3f67f7 |
manage_files_pattern($1, var_log_t, var_log_t)
|
|
Chris PeBenito |
17de1b |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
########################################
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## All of the rules required to administrate
|
|
Chris PeBenito |
eaed90 |
## the audit environment
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## <param name="domain">
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## Domain allowed access.
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## </param>
|
|
Chris PeBenito |
c11057 |
## <param name="role">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## User role allowed access.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
eaed90 |
## <rolecap/>
|
|
Chris PeBenito |
eaed90 |
#
|
|
Chris PeBenito |
eaed90 |
interface(`logging_admin_audit',`
|
|
Chris PeBenito |
eaed90 |
gen_require(`
|
|
Chris PeBenito |
eaed90 |
type auditd_t, auditd_etc_t, auditd_log_t;
|
|
Chris PeBenito |
eaed90 |
type auditd_var_run_t;
|
|
Chris PeBenito |
06099d |
type auditd_initrc_exec_t;
|
|
Chris PeBenito |
eaed90 |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
allow $1 auditd_t:process { ptrace signal_perms };
|
|
Chris PeBenito |
eaed90 |
ps_process_pattern($1, auditd_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, auditd_etc_t, auditd_etc_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, auditd_etc_t, auditd_etc_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, auditd_log_t, auditd_log_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, auditd_log_t, auditd_log_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, auditd_var_run_t, auditd_var_run_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, auditd_var_run_t, auditd_var_run_t)
|
|
Chris PeBenito |
c11057 |
|
|
Chris PeBenito |
7a4c28 |
logging_run_auditctl($1, $2)
|
|
Chris PeBenito |
06099d |
|
|
Chris PeBenito |
06099d |
init_labeled_script_domtrans($1, auditd_initrc_exec_t)
|
|
Chris PeBenito |
06099d |
domain_system_change_exemption($1)
|
|
Chris PeBenito |
06099d |
role_transition $2 auditd_initrc_exec_t system_r;
|
|
Chris PeBenito |
06099d |
allow $2 system_r;
|
|
Chris PeBenito |
eaed90 |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
########################################
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## All of the rules required to administrate
|
|
Chris PeBenito |
eaed90 |
## the syslog environment
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## <param name="domain">
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## Domain allowed access.
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## </param>
|
|
Chris PeBenito |
06099d |
## <param name="role">
|
|
Chris PeBenito |
06099d |
## <summary>
|
|
Chris PeBenito |
06099d |
## User role allowed access.
|
|
Chris PeBenito |
06099d |
## </summary>
|
|
Chris PeBenito |
06099d |
## </param>
|
|
Chris PeBenito |
eaed90 |
## <rolecap/>
|
|
Chris PeBenito |
eaed90 |
#
|
|
Chris PeBenito |
eaed90 |
interface(`logging_admin_syslog',`
|
|
Chris PeBenito |
eaed90 |
gen_require(`
|
|
Chris PeBenito |
eaed90 |
type syslogd_t, klogd_t, syslog_conf_t;
|
|
Chris PeBenito |
eaed90 |
type syslogd_tmp_t, syslogd_var_lib_t;
|
|
Chris PeBenito |
eaed90 |
type syslogd_var_run_t, klogd_var_run_t;
|
|
Chris PeBenito |
eaed90 |
type klogd_tmp_t, var_log_t;
|
|
Chris PeBenito |
06099d |
type syslogd_initrc_exec_t;
|
|
Chris PeBenito |
eaed90 |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
allow $1 syslogd_t:process { ptrace signal_perms };
|
|
Chris PeBenito |
eaed90 |
allow $1 klogd_t:process { ptrace signal_perms };
|
|
Chris PeBenito |
eaed90 |
ps_process_pattern($1, syslogd_t)
|
|
Chris PeBenito |
eaed90 |
ps_process_pattern($1, klogd_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, klogd_var_run_t, klogd_var_run_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, klogd_var_run_t, klogd_var_run_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, klogd_tmp_t, klogd_tmp_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, klogd_tmp_t, klogd_tmp_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, syslogd_tmp_t, syslogd_tmp_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, syslogd_tmp_t, syslogd_tmp_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, syslog_conf_t, syslog_conf_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, syslog_conf_t, syslog_conf_t)
|
|
Chris PeBenito |
eaed90 |
files_etc_filetrans($1, syslog_conf_t, file)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, syslogd_var_lib_t, syslogd_var_lib_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, syslogd_var_lib_t, syslogd_var_lib_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
manage_dirs_pattern($1, syslogd_var_run_t, syslogd_var_run_t)
|
|
Chris PeBenito |
eaed90 |
manage_files_pattern($1, syslogd_var_run_t, syslogd_var_run_t)
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
logging_manage_all_logs($1)
|
|
Chris PeBenito |
06099d |
|
|
Chris PeBenito |
06099d |
init_labeled_script_domtrans($1, syslogd_initrc_exec_t)
|
|
Chris PeBenito |
06099d |
domain_system_change_exemption($1)
|
|
Chris PeBenito |
06099d |
role_transition $2 syslogd_initrc_exec_t system_r;
|
|
Chris PeBenito |
06099d |
allow $2 system_r;
|
|
Chris PeBenito |
eaed90 |
')
|
|
Chris PeBenito |
eaed90 |
|
|
Chris PeBenito |
eaed90 |
########################################
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## All of the rules required to administrate
|
|
Chris PeBenito |
eaed90 |
## the logging environment
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## <param name="domain">
|
|
Chris PeBenito |
eaed90 |
## <summary>
|
|
Chris PeBenito |
eaed90 |
## Domain allowed access.
|
|
Chris PeBenito |
eaed90 |
## </summary>
|
|
Chris PeBenito |
eaed90 |
## </param>
|
|
Chris PeBenito |
c11057 |
## <param name="role">
|
|
Chris PeBenito |
c11057 |
## <summary>
|
|
Chris PeBenito |
c11057 |
## User role allowed access.
|
|
Chris PeBenito |
c11057 |
## </summary>
|
|
Chris PeBenito |
c11057 |
## </param>
|
|
Chris PeBenito |
eaed90 |
## <rolecap/>
|
|
Chris PeBenito |
eaed90 |
#
|
|
Chris PeBenito |
eaed90 |
interface(`logging_admin',`
|
|
Chris PeBenito |
7a4c28 |
logging_admin_audit($1, $2)
|
|
Chris PeBenito |
06099d |
logging_admin_syslog($1, $2)
|
|
Chris PeBenito |
eaed90 |
')
|