2010-05-11 20:01:32 +02:00
|
|
|
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...
|
|
|
|
}
|
|
|
|
|
2011-12-25 13:33:11 +01:00
|
|
|
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
|
|
|
|
}
|
2010-05-11 20:01:32 +02:00
|
|
|
|
2011-12-25 13:33:11 +01:00
|
|
|
preserve_perms etc/rc.d/rc.fail2ban.new
|
2010-05-11 20:01:32 +02:00
|
|
|
config etc/logrotate.d/fail2ban.new
|
2010-05-13 00:36:23 +02:00
|
|
|
config etc/fail2ban/fail2ban.conf.new
|
|
|
|
config etc/fail2ban/jail.conf.new
|
2010-12-07 06:12:15 +01:00
|
|
|
|
2010-05-13 00:36:23 +02:00
|
|
|
for conf_file in etc/fail2ban/action.d/*.new; do
|
|
|
|
config $conf_file
|
|
|
|
done
|
|
|
|
for conf_file in etc/fail2ban/filter.d/*.new; do
|
|
|
|
config $conf_file
|
|
|
|
done
|