Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- # 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
- #
- # Update rc.local so that elogind will be functional after boot:
- if ! grep "rc.elogind" etc/rc.d/rc.local 1>/dev/null 2>/dev/null ; then
- cat <<_EOM_ >> etc/rc.d/rc.local
- if [ -x /etc/rc.d/rc.elogind -a -x /usr/libexec/elogind ]; then
- # Create runtime for elogind (standalone logind extracted from systemd):
- /etc/rc.d/rc.elogind
- fi
- _EOM_
- fi
Advertisement
Add Comment
Please, Sign In to add comment