diff options
Diffstat (limited to 'system/audit/doinst.sh')
-rw-r--r-- | system/audit/doinst.sh | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/system/audit/doinst.sh b/system/audit/doinst.sh new file mode 100644 index 0000000000000..fb88271cae0a8 --- /dev/null +++ b/system/audit/doinst.sh @@ -0,0 +1,36 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +preserve_perms() { + NEW="$1" + OLD="$(dirname ${NEW})/$(basename ${NEW} .new)" + if [ -e ${OLD} ]; then + cp -a ${OLD} ${NEW}.incoming + cat ${NEW} > ${NEW}.incoming + mv ${NEW}.incoming ${NEW} + fi + config ${NEW} +} + +preserve_perms etc/rc.d/rc.auditd.new +config etc/rc.d/rc.auditd.conf.new +config etc/audit/audit.rules.new +config etc/audit/auditd.conf.new +config etc/audisp/audispd.conf.new +config etc/audisp/zos-remote.conf.new +config etc/audisp/plugins.d/af_unix.conf.new +config etc/audisp/plugins.d/au-remote.conf.new +config etc/audisp/plugins.d/audispd-zos-remote.conf.new +config etc/audisp/plugins.d/syslog.conf.new +config etc/audisp/audisp-remote.conf.new + |