summaryrefslogtreecommitdiff
path: root/system/haveged/doinst.sh
diff options
context:
space:
mode:
authorErik Falor <ewfalor@gmail.com>2012-12-09 11:01:01 -0500
committerdsomero <xgizzmo@slackbuilds.org>2012-12-11 16:21:59 -0500
commit5d79d66d1c8d65e9a4e6bc4b7eccfaaa3a63655c (patch)
treeaa38d2e71a5a9125393a6ea186dfce1efc59fe2f /system/haveged/doinst.sh
parentba72f6af14a885c68540f12cefa957e45323037c (diff)
downloadslackbuilds-5d79d66d1c8d65e9a4e6bc4b7eccfaaa3a63655c.tar.gz
system/haveged: Added (A simple entropy daemon)
Signed-off-by: dsomero <xgizzmo@slackbuilds.org>
Diffstat (limited to 'system/haveged/doinst.sh')
-rw-r--r--system/haveged/doinst.sh28
1 files changed, 28 insertions, 0 deletions
diff --git a/system/haveged/doinst.sh b/system/haveged/doinst.sh
new file mode 100644
index 0000000000..b9e90c8608
--- /dev/null
+++ b/system/haveged/doinst.sh
@@ -0,0 +1,28 @@
+config() {
+ for infile in $1; do
+ NEW="$infile"
+ 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...
+ done
+}
+
+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.haveged.new
+