5 kx #!/bin/sh
5 kx
5 kx # Preserve new files
5 kx install_file() {
5 kx NEW="$1"
5 kx OLD="`dirname $NEW`/`basename $NEW .new`"
5 kx # If there's no file by that name, mv it over:
5 kx if [ ! -r $OLD ]; then
5 kx mv $NEW $OLD
5 kx elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy
5 kx rm $NEW
5 kx fi
5 kx # Otherwise, we leave the .new copy for the admin to consider...
5 kx }
5 kx
5 kx
5 kx # arg 1: the new package version
5 kx pre_install() {
5 kx /bin/true
5 kx }
5 kx
5 kx # arg 1: the new package version
5 kx post_install() {
5 kx # If there is a known buggy certwatch script with no local modifications, just replace it:
5 kx if [ "$(md5sum etc/cron.daily/certwatch 2> /dev/null)" = "f4cf63e557820781f40c4cac67a44d77 etc/cron.daily/certwatch" ]; then
5 kx cat etc/cron.daily/certwatch.new > etc/cron.daily/certwatch
5 kx touch -r etc/cron.daily/certwatch.new etc/cron.daily/certwatch
5 kx fi
5 kx
5 kx install_file etc/ssl/openssl.cnf.new
5 kx install_file etc/cron.daily/certwatch.new
5 kx
5 kx # Rehash certificates if the package is upgraded on a running system:
5 kx # Note that we have to be sure that we are on the working system
5 kx # on the target hardware ("proc/sys/kernel/osrelease" - relative path).
5 kx if [ -r proc/sys/kernel/osrelease -a -x /usr/bin/c_rehash ]; then
5 kx /usr/bin/c_rehash 1> /dev/null 2> /dev/null
5 kx fi
5 kx }
5 kx
5 kx # arg 1: the new package version
5 kx # arg 2: the old package version
5 kx pre_update() {
5 kx /bin/true
5 kx }
5 kx
5 kx # arg 1: the new package version
5 kx # arg 2: the old package version
5 kx post_update() {
5 kx post_install
5 kx }
5 kx
5 kx # arg 1: the old package version
5 kx pre_remove() {
5 kx /bin/true
5 kx }
5 kx
5 kx # arg 1: the old package version
5 kx post_remove() {
5 kx /bin/true
5 kx }
5 kx
5 kx
5 kx operation=$1
5 kx shift
5 kx
5 kx $operation $*