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... } 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 } if [ -x /usr/bin/update-desktop-database ]; then /usr/bin/update-desktop-database usr/share/applications >/dev/null 2>&1 fi if [ -x /usr/bin/update-mime-database ]; then /usr/bin/update-mime-database usr/share/mime >/dev/null 2>&1 fi if [ -e usr/share/icons/hicolor/icon-theme.cache ]; then if [ -x /usr/bin/gtk-update-icon-cache ]; then /usr/bin/gtk-update-icon-cache usr/share/icons/hicolor >/dev/null 2>&1 fi fi # Check for vboxusers group here if ! grep ^vboxusers: /etc/group 2>&1 > /dev/null; then /usr/sbin/groupadd -g 215 vboxusers fi # Check for vboxhost account here if ! grep ^vboxhost: /etc/passwd 2>&1 > /dev/null; then /usr/sbin/useradd -d /var/lib/virtualbox -s /bin/bash -u 215 -g 215 -c "VirtualBox Headless" vboxhost fi mkdir -p var/lib/virtualbox chown vboxhost:vboxusers var/lib/virtualbox # Prepare the new configuration files config etc/vbox/vbox.cfg.new config etc/vbox/autorun.cfg.new config etc/default/virtualbox.new preserve_perms etc/rc.d/rc.virtualbox.new