summaryrefslogtreecommitdiffstats
path: root/testing/source/elogind/doinst.sh
diff options
context:
space:
mode:
Diffstat (limited to 'testing/source/elogind/doinst.sh')
-rw-r--r--testing/source/elogind/doinst.sh39
1 files changed, 39 insertions, 0 deletions
diff --git a/testing/source/elogind/doinst.sh b/testing/source/elogind/doinst.sh
new file mode 100644
index 000000000..e39e2aee3
--- /dev/null
+++ b/testing/source/elogind/doinst.sh
@@ -0,0 +1,39 @@
+# Handle the incoming configuration files:
+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 permissions while moving into place:
+preserve_perms etc/rc.d/rc.elogind.new
+config etc/elogind/logind.conf.new
+config etc/elogind/sleep.conf.new
+config etc/elogind/sleep.conf.d/10-elogind.conf.new
+config etc/pam.d/elogind-user.new
+
+# Reload elogind-daemon:
+if pgrep -f elogind-daemon 1> /dev/null 2> /dev/null ; then
+ pkill -HUP -f elogind-daemon
+fi
+