From bf01b31812c5b464f18c9344aca6a6cc5988bf35 Mon Sep 17 00:00:00 2001 From: ArTourter Date: Wed, 25 Jul 2012 17:42:37 -0500 Subject: network/shorewall-core: Added (core shorewall components) Signed-off-by: Robby Workman --- network/shorewall-core/doinst.sh | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 network/shorewall-core/doinst.sh (limited to 'network/shorewall-core/doinst.sh') diff --git a/network/shorewall-core/doinst.sh b/network/shorewall-core/doinst.sh new file mode 100644 index 0000000000..b97f70f822 --- /dev/null +++ b/network/shorewall-core/doinst.sh @@ -0,0 +1,28 @@ +#!/bin/sh +# vim: et ts=2 sw=2 + +config() { + NEW="$1" + OLD="${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.firewall.new + -- cgit v1.2.3